MyBitis(iBitis)系列随笔之三:简单实现CRUD

时间:2022-06-25 07:44:29

Mybitis(iBitis)实现对对象增删改查操作要借助<select/>查询,<insert/>增加,<update/>更新,<delete/>删除 标签来操作。

值得注意的有两点:
  1、在对对象进行增删改时,SqlSession session = sqlSessionFactory.openSession();获取的session。必选执行session.commit();否则操作无效。
  2、Mybitis与hibernate一样,插入数据后会把id值赋值给缓存中对象

还是接着上一讲的代码继续改动
UserMapper.xml

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="user">
  6. <resultMap id="userResultMap" type="user">
  7. <id property="id" column="id"/>
  8. <result property="userName" column="name"/>
  9. <result property="password" column="pass"/>
  10. </resultMap>
  11. <!--resultType 表示com.jefry.User这样一个实体对象 -->
  12. <select id="selectUser" parameterType="int"  resultMap="userResultMap" >
  13. select * from t_user where id = #{id}
  14. </select>
  15. <!--增加操作-->
  16. <insert id="addUser" parameterType="user"
  17. useGeneratedKeys="true" keyProperty="id">
  18. insert into t_user(name,pass) values(#{userName},#{password})
  19. </insert>
  20. <!--更新操作-->
  21. <update id="modifyUser" parameterType="user">
  22. update t_user set name=#{userName}, pass=#{password} where id=#{id}
  23. </update>
  24. <delete id="deleteUser" parameterType="int">
  25. delete from t_user where id=#{id}
  26. </delete>
  27. </mapper>

测试代码

  1. public class Test {
  2. static String resource = "mybatis-config.xml";
  3. public static void main(String[] args) throws IOException {
  4. // TODO Auto-generated method stub
  5. InputStream inputStream = Resources.getResourceAsStream(resource);
  6. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  7. SqlSession session = sqlSessionFactory.openSession();
  8. try {
  9. //User.selectUser中User对应UserMapper.xml文件中标签<mapper namespace="User"> namespace的值
  10. //selectUser 对应UserMapper.xml文件中标签<select id="selectUser" parameterType="int" resultType="com.jefry.User">中id值
  11. User user = session.selectOne("user.selectUser", 1);
  12. System.out.println("user.getName()=" +  user.getPassword());
  13. User addUser = new User();
  14. addUser.setUserName("NEWWWWW");
  15. addUser.setPassword("111111");
  16. session.insert("user.addUser", addUser);
  17. //插入操作
  18. User modifyUser = new User();
  19. modifyUser.setUserName("NEWWWWW");
  20. modifyUser.setPassword("111111");
  21. modifyUser.setId(1);
  22. //修改用户
  23. session.update("user.modifyUser", addUser);
  24. //删除操作
  25. session.delete("user.deleteUser",2);
  26. //这里必须commit,否则增删改无效
  27. session.commit();
  28. //与hibernate一样,插入数据后会把id值赋值给缓存中的id
  29. System.out.println("addUser.getId()" + addUser.getId() );
  30. } finally {
  31. session.close();
  32. }
  33. }
  34. }