MyBatis學習總結(二)——使用MyBatis對錶執行CRUD操做

  上一篇博文MyBatis學習總結(一)——MyBatis快速入門中咱們講了如何使用Mybatis查詢users表中的數據,算是對MyBatis有一個初步的入門了,今天講解一下如何使用MyBatis對users表執行CRUD操做。本文中使用到的測試環境是上一篇博文中的測試環境。html

1、使用MyBatis對錶執行CRUD操做——基於XML的實現

一、定義sql映射xml文件java

  userMapper.xml文件的內容以下:mysql

 1 <?xml version="1.0" encoding="UTF-8" ?>
 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 3 <!-- 爲這個mapper指定一個惟一的namespace,namespace的值習慣上設置成包名+sql映射文件名,這樣就可以保證namespace的值是惟一的
 4 例如namespace="me.gacl.mapping.userMapper"就是me.gacl.mapping(包名)+userMapper(userMapper.xml文件去除後綴)
 5  -->
 6 <mapper namespace="me.gacl.mapping.userMapper">
 7     <!-- 在select標籤中編寫查詢的SQL語句, 設置select標籤的id屬性爲getUser,id屬性值必須是惟一的,不可以重複
 8     使用parameterType屬性指明查詢時使用的參數類型,resultType屬性指明查詢返回的結果集類型
 9     resultType="me.gacl.domain.User"就表示將查詢結果封裝成一個User類的對象返回
10     User類就是users表所對應的實體類
11     -->
12     <!-- 
13         根據id查詢獲得一個user對象
14      -->
15     <select id="getUser" parameterType="int" 
16         resultType="me.gacl.domain.User">
17         select * from users where id=#{id}
18     </select>
19     
20     <!-- 建立用戶(Create) -->
21     <insert id="addUser" parameterType="me.gacl.domain.User">
22         insert into users(name,age) values(#{name},#{age})
23     </insert>
24     
25     <!-- 刪除用戶(Remove) -->
26     <delete id="deleteUser" parameterType="int">
27         delete from users where id=#{id}
28     </delete>
29     
30     <!-- 修改用戶(Update) -->
31     <update id="updateUser" parameterType="me.gacl.domain.User">
32         update users set name=#{name},age=#{age} where id=#{id}
33     </update>
34     
35     <!-- 查詢所有用戶-->
36     <select id="getAllUsers" resultType="me.gacl.domain.User">
37         select * from users
38     </select>
39     
40 </mapper>

  單元測試類代碼以下:sql

 1 package me.gacl.test;
 2 
 3 import java.util.List;
 4 import me.gacl.domain.User;
 5 import me.gacl.util.MyBatisUtil;
 6 import org.apache.ibatis.session.SqlSession;
 7 import org.junit.Test;
 8 
 9 public class TestCRUDByXmlMapper {
10 
11     @Test
12     public void testAdd(){
13         //SqlSession sqlSession = MyBatisUtil.getSqlSession(false);
14         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
15         /**
16          * 映射sql的標識字符串,
17          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標籤的namespace屬性的值,
18          * addUser是insert標籤的id屬性值,經過insert標籤的id屬性值就能夠找到要執行的SQL
19          */
20         String statement = "me.gacl.mapping.userMapper.addUser";//映射sql的標識字符串
21         User user = new User();
22         user.setName("用戶孤傲蒼狼");
23         user.setAge(20);
24         //執行插入操做
25         int retResult = sqlSession.insert(statement,user);
26         //手動提交事務
27         //sqlSession.commit();
28         //使用SqlSession執行完SQL以後須要關閉SqlSession
29         sqlSession.close();
30         System.out.println(retResult);
31     }
32     
33     @Test
34     public void testUpdate(){
35         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
36         /**
37          * 映射sql的標識字符串,
38          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標籤的namespace屬性的值,
39          * updateUser是update標籤的id屬性值,經過update標籤的id屬性值就能夠找到要執行的SQL
40          */
41         String statement = "me.gacl.mapping.userMapper.updateUser";//映射sql的標識字符串
42         User user = new User();
43         user.setId(3);
44         user.setName("孤傲蒼狼");
45         user.setAge(25);
46         //執行修改操做
47         int retResult = sqlSession.update(statement,user);
48         //使用SqlSession執行完SQL以後須要關閉SqlSession
49         sqlSession.close();
50         System.out.println(retResult);
51     }
52     
53     @Test
54     public void testDelete(){
55         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
56         /**
57          * 映射sql的標識字符串,
58          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標籤的namespace屬性的值,
59          * deleteUser是delete標籤的id屬性值,經過delete標籤的id屬性值就能夠找到要執行的SQL
60          */
61         String statement = "me.gacl.mapping.userMapper.deleteUser";//映射sql的標識字符串
62         //執行刪除操做
63         int retResult = sqlSession.delete(statement,5);
64         //使用SqlSession執行完SQL以後須要關閉SqlSession
65         sqlSession.close();
66         System.out.println(retResult);
67     }
68     
69     @Test
70     public void testGetAll(){
71         SqlSession sqlSession = MyBatisUtil.getSqlSession();
72         /**
73          * 映射sql的標識字符串,
74          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標籤的namespace屬性的值,
75          * getAllUsers是select標籤的id屬性值,經過select標籤的id屬性值就能夠找到要執行的SQL
76          */
77         String statement = "me.gacl.mapping.userMapper.getAllUsers";//映射sql的標識字符串
78         //執行查詢操做,將查詢結果自動封裝成List<User>返回
79         List<User> lstUsers = sqlSession.selectList(statement);
80         //使用SqlSession執行完SQL以後須要關閉SqlSession
81         sqlSession.close();
82         System.out.println(lstUsers);
83     }
84 }

2、使用MyBatis對錶執行CRUD操做——基於註解的實現

  一、定義sql映射的接口數據庫

  UserMapperI接口的代碼以下:apache

 1 package me.gacl.mapping;
 2 
 3 import java.util.List;
 4 import me.gacl.domain.User;
 5 import org.apache.ibatis.annotations.Delete;
 6 import org.apache.ibatis.annotations.Insert;
 7 import org.apache.ibatis.annotations.Select;
 8 import org.apache.ibatis.annotations.Update;
 9 
10 /**
11  * @author gacl
12  * 定義sql映射的接口,使用註解指明方法要執行的SQL
13  */
14 public interface UserMapperI {
15 
16     //使用@Insert註解指明add方法要執行的SQL
17     @Insert("insert into users(name, age) values(#{name}, #{age})")
18     public int add(User user);
19     
20     //使用@Delete註解指明deleteById方法要執行的SQL
21     @Delete("delete from users where id=#{id}")
22     public int deleteById(int id);
23     
24     //使用@Update註解指明update方法要執行的SQL
25     @Update("update users set name=#{name},age=#{age} where id=#{id}")
26     public int update(User user);
27     
28     //使用@Select註解指明getById方法要執行的SQL
29     @Select("select * from users where id=#{id}")
30     public User getById(int id);
31     
32     //使用@Select註解指明getAll方法要執行的SQL
33     @Select("select * from users")
34     public List<User> getAll();
35 }

  須要說明的是,咱們不須要針對UserMapperI接口去編寫具體的實現類代碼,這個具體的實現類由MyBatis幫咱們動態構建出來,咱們只須要直接拿來使用便可。session

  二、在conf.xml文件中註冊這個映射接口mybatis

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
 3 <configuration>
 4     <environments default="development">
 5         <environment id="development">
 6             <transactionManager type="JDBC" />
 7             <!-- 配置數據庫鏈接信息 -->
 8             <dataSource type="POOLED">
 9                 <property name="driver" value="com.mysql.jdbc.Driver" />
10                 <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
11                 <property name="username" value="root" />
12                 <property name="password" value="XDP" />
13             </dataSource>
14         </environment>
15     </environments>
16     
17     <mappers>
18         <!-- 註冊userMapper.xml文件, 
19         userMapper.xml位於me.gacl.mapping這個包下,因此resource寫成me/gacl/mapping/userMapper.xml-->
20         <mapper resource="me/gacl/mapping/userMapper.xml"/>
21         <!-- 註冊UserMapper映射接口-->
22         <mapper class="me.gacl.mapping.UserMapperI"/>
23     </mappers>
24     
25 </configuration>

  單元測試類的代碼以下:app

 1 package me.gacl.test;
 2 
 3 import java.util.List;
 4 import me.gacl.domain.User;
 5 import me.gacl.mapping.UserMapperI;
 6 import me.gacl.util.MyBatisUtil;
 7 import org.apache.ibatis.session.SqlSession;
 8 import org.junit.Test;
 9 
10 public class TestCRUDByAnnotationMapper {
11 
12     @Test
13     public void testAdd(){
14         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
15         //獲得UserMapperI接口的實現類對象,UserMapperI接口的實現類對象由sqlSession.getMapper(UserMapperI.class)動態構建出來
16         UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
17         User user = new User();
18         user.setName("用戶xdp");
19         user.setAge(20);
20         int add = mapper.add(user);
21         //使用SqlSession執行完SQL以後須要關閉SqlSession
22         sqlSession.close();
23         System.out.println(add);
24     }
25     
26     @Test
27     public void testUpdate(){
28         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
29         //獲得UserMapperI接口的實現類對象,UserMapperI接口的實現類對象由sqlSession.getMapper(UserMapperI.class)動態構建出來
30         UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
31         User user = new User();
32         user.setId(3);
33         user.setName("孤傲蒼狼_xdp");
34         user.setAge(26);
35         //執行修改操做
36         int retResult = mapper.update(user);
37         //使用SqlSession執行完SQL以後須要關閉SqlSession
38         sqlSession.close();
39         System.out.println(retResult);
40     }
41     
42     @Test
43     public void testDelete(){
44         SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
45         //獲得UserMapperI接口的實現類對象,UserMapperI接口的實現類對象由sqlSession.getMapper(UserMapperI.class)動態構建出來
46         UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
47         //執行刪除操做
48         int retResult = mapper.deleteById(7);
49         //使用SqlSession執行完SQL以後須要關閉SqlSession
50         sqlSession.close();
51         System.out.println(retResult);
52     }
53     
54     @Test
55     public void testGetUser(){
56         SqlSession sqlSession = MyBatisUtil.getSqlSession();
57         //獲得UserMapperI接口的實現類對象,UserMapperI接口的實現類對象由sqlSession.getMapper(UserMapperI.class)動態構建出來
58         UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
59         //執行查詢操做,將查詢結果自動封裝成User返回
60         User user = mapper.getById(8);
61         //使用SqlSession執行完SQL以後須要關閉SqlSession
62         sqlSession.close();
63         System.out.println(user);
64     }
65     
66     @Test
67     public void testGetAll(){
68         SqlSession sqlSession = MyBatisUtil.getSqlSession();
69         //獲得UserMapperI接口的實現類對象,UserMapperI接口的實現類對象由sqlSession.getMapper(UserMapperI.class)動態構建出來
70         UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
71         //執行查詢操做,將查詢結果自動封裝成List<User>返回
72         List<User> lstUsers = mapper.getAll();
73         //使用SqlSession執行完SQL以後須要關閉SqlSession
74         sqlSession.close();
75         System.out.println(lstUsers);
76     }
77 }

  用到的MyBatisUtil工具類代碼以下:dom

 1 package me.gacl.util;
 2 
 3 import java.io.InputStream;
 4 
 5 import org.apache.ibatis.session.SqlSession;
 6 import org.apache.ibatis.session.SqlSessionFactory;
 7 import org.apache.ibatis.session.SqlSessionFactoryBuilder;
 8 
 9 public class MyBatisUtil {
10 
11     /**
12      * 獲取SqlSessionFactory
13      * @return SqlSessionFactory
14      */
15     public static SqlSessionFactory getSqlSessionFactory() {
16         String resource = "conf.xml";
17         InputStream is = MyBatisUtil.class.getClassLoader().getResourceAsStream(resource);
18         SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
19         return factory;
20     }
21     
22     /**
23      * 獲取SqlSession
24      * @return SqlSession
25      */
26     public static SqlSession getSqlSession() {
27         return getSqlSessionFactory().openSession();
28     }
29     
30     /**
31      * 獲取SqlSession
32      * @param isAutoCommit 
33      *         true 表示建立的SqlSession對象在執行完SQL以後會自動提交事務
34      *         false 表示建立的SqlSession對象在執行完SQL以後不會自動提交事務,這時就須要咱們手動調用sqlSession.commit()提交事務
35      * @return SqlSession
36      */
37     public static SqlSession getSqlSession(boolean isAutoCommit) {
38         return getSqlSessionFactory().openSession(isAutoCommit);
39     }
40 }

   以上的相關代碼是所有測試經過的,關於使用MyBatis對錶執行CRUD操做的內容就這麼多。

相關文章
相關標籤/搜索