mybatis-mybatis的基本配置

SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE configuration  
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  
  "http://mybatis.org/dtd/mybatis-3-config.dtd"> 

<configuration>
	<!-- 加载属性文件 -->
	<properties resource="db.properties">
		<!-- properties中还可以配置一些属性名和属性值 -->
		<!-- properties name="jdbc.driver" value="" -->
	</properties>
	
	<!-- 全局配置参数 -->
	<!-- <settring></settring>  -->

	<!-- 别名定义 -->
	<typeAliases>
		<!-- 针对单个别名定义 
			type:类型的路径
			alias:别名
		-->
		<!-- <typeAlias type="com.itvast.mybatis.po.Employee" alias="employee"></typeAlias>  -->
		
		<!-- 批量别名定义 (常用)
		指定包名,mybatis自动扫描包中的po类,自动定义别名,别名就是类名(首字母大写或小写都可以)
		-->
		<package name="com.itvast.mybatis.po"/>
	</typeAliases>

	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC"/>
			<dataSource type="POOLED">
				<property name="driver" value="${jdbc.driver}"/>
				<property name="url" value="${jdbc.url}"/>
				<property name="username" value="${jdbc.username}"/>
				<property name="password" value="${jdbc.password}"/>
			</dataSource>
		</environment>
	</environments>
	<mappers>
		<!-- 同股票resource加载单个的映射文件 -->
		<mapper resource="sqlmap/User.xml"/>
		<!-- <mapper resource="mapper/UserMapper.xml"/> -->
		
		<!-- 通过mapper接口加载映射文件
			遵循一些规范:需要将mapper接口的类名和mapper.xml映射文件名称保持一致,且在一个目录
			上边规范的前提是:使用的是mapper代理方法
		 -->
		<!-- <mapper class="com.itcast.mybatis.mapper.EmployeeMapper"/> -->
		<!-- 批量加载mapper
		指定mapper接口的报名,mybatis自动扫描包下边所有mapper接口进行加载
		遵循一些规范:需要将mapper接口的类名和mapper.xml映射文件名称保持一致,且在一个目录
			上边规范的前提是:使用的是mapper代理方法
		 -->
		 <package name="com.itcast.mybatis.mapper"></package>
	</mappers>
</configuration>
User.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!-- namesoace命名空间,作用就是对sql进行分类管理,理解sql隔离 
注意:使用mapper代理方法开发,namespace有特殊重要的作用
-->
<mapper namespace="test">
	<!-- 在映射文件中配置很多sql语句 -->
	<!-- 通过id查询用户表的记录 -->
	<!-- 通过select执行数据库查询
	id:表示映射文件中的sql,成为statement的id
	将sql语句封装到(mappedStatement对象中,所以将id成为statement的id
	#{}表示一个占位符
	parameterType:指定输入参数的类型,这里指定int型
	#{id}:其中的id表示接入输入的参数,参数名称就是id,如果输入参数是简单类型,#{}中的参数名可以任意,可以value或其他名称
	 resultType:指定sql输出结果的所映射的java对象类型,select指定resultType表示将单条记录映射成的java对象
	 -->
	<select id="findUserById" parameterType="int" resultType="com.itvast.mybatis.po.Employee">
		select * from Employee where id=#{id}
	</select>
	
	<!-- 根据用户名称模糊查询用户信息 
	 resultType:注定就是单条记录所映射的java对象类型
	 ${}:表示清洁sql串,将接受到参数的内容不加任何修饰凭借在sql中
	 使用${}清洁sql,引起sql注入
	 ${value}:接受输入参数的内容,如果传入类型是简单类型,${}中只能使用value
	-->
	<select id="findUserByName" parameterType="java.lang.String" resultType="com.itvast.mybatis.po.Employee">
		select * from Employee where name like '%${value}%'
	</select>
	<!-- 添加用户 
	parameterType:指定输入参数类型是pojo(包括用户信息)
	#{}中指定pojo的属性名,接受到pojo对象的属性值,mybatis通过OGNL获取对象的属性值
	-->
	<!-- useGeneratedKeys="true" keyProperty="id" 获得自增长的id返回到javaBean里的"id"属性里 -->
	<insert id="insertUser" parameterType="com.itvast.mybatis.po.Employee" useGeneratedKeys="true" keyProperty="id">
		insert into Employee(email,hiredate,name,salary,pwd,grade,department_id) values(#{email},#{hiredate},#{name},#{salary},#{pwd},#{grade},#{department_id})
	</insert>
	
	<!-- 删除用户
	根据id删除影虎,需要输入id值
	 -->
	 <delete id="delectEmployee" parameterType="java.lang.Integer">
	 	delete from Employee where id =#{id}
	 </delete>
	 
	 <!-- 根据id更新用户 
	 分析:
	 需要传入用户的id
	 需要传入用户的更新信息
	 parameterType指定Employee对象,包括id和更新信息,注意:id必须存在
	 #{id}:从输入Employee对象中获取id属性值
	 -->
	 <update id="updateEmployee" parameterType="com.itvast.mybatis.po.Employee">
		 update Employee set department_id=#{department_id},email=#{email},grade=#{grade},hiredate=#{hiredate},name=#{name},pwd=#{pwd},salary=#{salary} where id =#{id}
	 </update>
</mapper>
MybatisFirst.java:
package com.itcast.mybatis.first;

import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import com.itvast.mybatis.po.Employee;

public class MybatisFirst {
	public static void main(String []args){
		//根据id查询用户信息,得到一条记录集
		try {
			new MybatisFirst().updateEmployeeTest();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	
	//根据id返回User对象
	public void findUserByIdTest() throws IOException{
		SqlSession sqlsession=null;
		try{
		//mybatis配置文件
		String resource="SqlMapConfig.xml";
		//得到配置文件
		InputStream inputStream=Resources.getResourceAsStream(resource);
		//创建会话工厂,传入mybatis的配置文件信息
		SqlSessionFactory sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);
		//通过工厂得到SqlSerssion
		sqlsession=sqlSessionFactory.openSession();
		//通过SqlSession操作数据库
		//第一个参数:映射文件中statement的id,等于namespace+statement的id
		//第二个参数:指定和映射文件中所匹配的parameterType类型的参数
		//sqlSession.selectOne结果与映射文件中所匹配的resultType类型的对象
		Employee employee=sqlsession.selectOne("test.findUserById", 1);
		System.out.println(employee.getName());
		}finally{
	//	释放支援
		sqlsession.close();
		}
	}
	
	//根据用户名称模糊查询列表
	public void findUserByNameTest() throws IOException{
		SqlSession sqlsession=null;
		try{
		//mybatis配置文件
		String resource="SqlMapConfig.xml";
		//得到配置文件
		InputStream inputStream=Resources.getResourceAsStream(resource);
		//创建会话工厂,传入mybatis的配置文件信息
		SqlSessionFactory sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);
		//通过工厂得到SqlSerssion
		sqlsession=sqlSessionFactory.openSession();
		//通过SqlSession操作数据库
		//第一个参数:映射文件中statement的id,等于namespace+statement的id
		//第二个参数:指定和映射文件中所匹配的parameterType类型的参数
		//sqlSession.selectOne结果与映射文件中所匹配的resultType类型的对象
		List<Employee> list=sqlsession.selectList("test.findUserByName", "韩逸俊");
		for(Employee a:list){
			System.out.println(a);
		}
		}finally{
	//	释放支援
		sqlsession.close();
		}
	}
		
		//根据用户名称模糊查询列表
		public void insertUserTest() throws IOException{
			SqlSession sqlsession=null;
			try{
			//mybatis配置文件
			String resource="SqlMapConfig.xml";
			//得到配置文件
			InputStream inputStream=Resources.getResourceAsStream(resource);
			//创建会话工厂,传入mybatis的配置文件信息
			SqlSessionFactory sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);
			//通过工厂得到SqlSerssion
			sqlsession=sqlSessionFactory.openSession();
			//通过SqlSession操作数据库
			Employee employee=new Employee();
			employee.setDepartment_id(1);
			employee.setEmail("qwe490620651@qq.com");
			employee.setGrade(1);
			employee.setHiredate(new Date());
			employee.setName("大树");
			employee.setPwd("hyj84884824");
			employee.setSalary(6300f);
			
			
			sqlsession.insert("test.insertUser", employee);
			//提交事务
			sqlsession.commit();
			
			//获取用户信息主键
			System.out.println(employee.getId());
			
			}finally{
		//	释放支援
			sqlsession.close();
			}
		}
		
		public void delectEmployeeTest() throws IOException{
			SqlSession sqlsession=null;
			try{
				InputStream inputStream=Resources.getResourceAsStream("SqlMapConfig.xml");
				SqlSessionFactory sqlsessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
				sqlsession=sqlsessionFactory.openSession();
				
				int id=1008;
				sqlsession.delete("test.delectEmployee",id);
				sqlsession.commit();
			}finally{
				sqlsession.close();
			}
			
			
		}
		
		public void updateEmployeeTest() throws IOException{
			SqlSession sqlsession=null;
			try{
				InputStream inputStream=Resources.getResourceAsStream("SqlMapConfig.xml");
				SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
				sqlsession=sqlSessionFactory.openSession();
				
				Employee employee=new Employee();
				employee.setId(1007);
				employee.setDepartment_id(1);
				employee.setEmail("m15915905571@163.com");
				employee.setGrade(1);
				employee.setHiredate(new Date());
				employee.setName("深渊巨口");
				employee.setPwd("hyj84884824");
				employee.setSalary(6300f);
				sqlsession.update("test.updateEmployee",employee);
				sqlsession.commit();
			}finally{
				sqlsession.close();
			}
		}
			
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值