Mybatis-增删改查

配置文件

<?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>
    <environments default="development">
        <environment id="development">
        	<!-- 使用jdbc事务管理 -->
            <transactionManager type="JDBC" />
            <!-- 配置数据库连接信息 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
                <property name="username" value="root" />
                <property name="password" value="123456" />
            </dataSource>
        </environment>
    </environments>
    <!-- 加载映射文件 -->
    <mappers>
    	<mapper resource="sqlmap/userMapper.xml"/>
    </mappers>
</configuration>


<?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">
<!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的
例如namespace="mybatis.com.entity.userMapper"就是mybatis.com.entity(包名)+userMapper(userMapper.xml文件去除后缀)
 -->
<mapper namespace="mybatis.com.entity.userMapper">
    <!-- 
    	在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复
    	使用parameterType属性指明查询时使用的参数类型,resultType属性指明查询返回的结果集类型
    	resultType="mybatis.com.entity.User"就表示将查询结果封装成一个User类的对象返回
   		User类就是users表所对应的实体类
    -->
    <!-- 
   		     根据id查询得到一个user对象
     -->
    <select id="getUser" parameterType="int"  resultType="mybatis.com.entity.User">
        select * from user where id=#{id}
    </select>
    <!-- 
    	根据名字模糊查询
     -->
     <select id="getUsers" parameterType="java.lang.String" resultType="mybatis.com.entity.User">
     	select * from user where name like '%${value}%'
     </select>
   <!-- 
     	增加用户
      -->
     <insert id="addUser" parameterType="mybatis.com.entity.User">
     	<!-- 
     		返回增加后的用户id   
     		只适用于自增主键
     		keyProperty:将查询到的主键设置到parameterType对象指定的属性
     		order:相对于insert语句的执行时间
     		resultType:返回的结果类型
     	 -->
     	<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
     		select last_insert_id()
     	</selectKey>
     	insert into user(name,password) value(#{name},#{password})   
     </insert>
      
      <!-- 
      	删除用户
       -->
      <delete id="deleteUser" parameterType="java.lang.Integer">
      		delete from user where id = #{id}
      	
      </delete>
      <!-- 
      	更新用户
       -->
     <update id="updateUser" parameterType="mybatis.com.entity.User">
     	update user set name = #{name}, password = #{password} where id = #{id}
     </update>  
</mapper>


根据id查询user

@Test
    public void findUserById() throws IOException{
	
	//配置文件名
	String resource = "SqlMapConfig.xml"; 
	//创建配置文件文件流
	InputStream inputStream = Resources.getResourceAsStream(resource);
	// 创建会话工厂
	SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
	//获取SqlSession
	SqlSession sqlSession = sqlSessionFactory.openSession();
	//通过SqlSession操作数据库
	/*
	 * 第一个参数:标识要执行的sql语句:namespace+id
	 * 第二个参数:指定和映射文件parameterType对应类型的参数
	 * 返回结果是与resultType对应类型的对象
	 */
	User user = sqlSession.selectOne("mybatis.com.entity.userMapper.getUser",1);
	System.out.println(user);
	//释放资源
	sqlSession.close();
    }

根据名字模糊查询

@Test
    public void findByName() throws IOException{
	
	//配置文件
	String resource = "SqlMapConfig.xml";
	//获取文件流
	InputStream inputStream = Resources.getResourceAsStream(resource);
	//创建会话工厂
	SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
	//获取sqlsession
	SqlSession sqlSession = sqlSessionFactory.openSession();
	
	List<User> users =  sqlSession.selectList("mybatis.com.entity.userMapper.getUsers","a");
	
	System.out.println(users);
	sqlSession.close();
	
    }

增加用户

@Test
    public void AddUser() throws IOException{
	//配置文件
	String resource = "SqlMapConfig.xml";
	//获取文件流
	InputStream inputStream = Resources.getResourceAsStream(resource);
	//创建会话工厂
	SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
	//获取sqlsession
	SqlSession sqlSession = sqlSessionFactory.openSession();
	User user = new User();
	user.setName("b");
	user.setPassword("123456");
	sqlSession.insert("mybatis.com.entity.userMapper.addUser",user);
	sqlSession.commit();
	sqlSession.close();
	//获取返回的主键
	System.out.println(user.getId());
	
    }

猜你喜欢

转载自blog.csdn.net/QEcode/article/details/82823369