Mybatis如何使用注解優(yōu)化代碼
entity層代碼不變,因?yàn)槭莾?yōu)化,所以在dao層新增了一個(gè)通過(guò)id查詢用戶的功能,現(xiàn)在來(lái)演示一下優(yōu)化前后的代碼對(duì)比,希望你們喜歡
entity層代碼不變,dao層中的UserMapper中添加一個(gè)方法
/**
* 根據(jù)id查詢用戶
*/
User findUserById(int id);
在UserMapper.xml映射文件中添加
<select id="findUserById" parameterType="int" resultType="com.vg.entity.User"> select * from user where id = #{id}; </select>
在test層中的test中使用沒(méi)有優(yōu)化的代碼展示
package com.vg.test; import com.vg.dao.UserMapper; import com.vg.entity.User; 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 org.junit.Test; import java.io.InputStream; import java.util.List; /** * 測(cè)試類 */ public class TestUserMapper { /** * 測(cè)試方法:查詢所有學(xué)生 * SqlSessionFactoryBuilder => SqlSessionFactory => SqlSession:相當(dāng)于JDBC中的Connection對(duì)象,提供了操作數(shù)據(jù)庫(kù)的CRUD方法 */ @Test public void testFindAllUsers()throws Exception{ // 1. 通過(guò)Resources類,加載sqlMapConfig.xml,得到文件輸入流對(duì)象 // Resources類作用:專門讀取src目錄下的資源文件 InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml"); // 2. 實(shí)例化會(huì)話工廠創(chuàng)建類SqlSessionFactoryBuilder SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); // 3. 通過(guò)會(huì)話工廠創(chuàng)建類,讀取上面的輸入流,得到會(huì)話工廠SqlSessionFactory類 SqlSessionFactory sqlSessionFactory = builder.build(in); // 4. 使用SqlSessionFactory對(duì)象,創(chuàng)建SqlSession對(duì)象 // a) 它相當(dāng)于JDBC中的Connection對(duì)象,提供了操作數(shù)據(jù)庫(kù)的CRUD方法 // b) 它提供了一個(gè)getMapper()方法,獲取接口的實(shí)現(xiàn)對(duì)象。 SqlSession sqlSession = sqlSessionFactory.openSession(); // 5. 獲取接口 UserMapper 實(shí)現(xiàn)類對(duì)象(代理對(duì)象) UserMapper userMapper = sqlSession.getMapper(UserMapper.class); System.out.println("userMapper = " +userMapper); // 6. 執(zhí)行數(shù)據(jù)庫(kù)的查詢操作,輸出用戶信息 List<User> userList = userMapper.findAllUsers(); for (User user : userList) { System.out.println(user); } // 7. 關(guān)閉會(huì)話,釋放資源。 sqlSession.close(); } @Test public void testFindUserById()throws Exception{ // 1. 通過(guò)Resources類,加載sqlMapConfig.xml,得到文件輸入流對(duì)象 // Resources類作用:專門讀取src目錄下的資源文件 InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml"); // 2. 實(shí)例化會(huì)話工廠創(chuàng)建類SqlSessionFactoryBuilder SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); // 3. 通過(guò)會(huì)話工廠創(chuàng)建類,讀取上面的輸入流,得到會(huì)話工廠SqlSessionFactory類 SqlSessionFactory sqlSessionFactory = builder.build(in); // 4. 使用SqlSessionFactory對(duì)象,創(chuàng)建SqlSession對(duì)象 // a) 它相當(dāng)于JDBC中的Connection對(duì)象,提供了操作數(shù)據(jù)庫(kù)的CRUD方法 // b) 它提供了一個(gè)getMapper()方法,獲取接口的實(shí)現(xiàn)對(duì)象。 SqlSession sqlSession = sqlSessionFactory.openSession(); // 5. 獲取接口 UserMapper 實(shí)現(xiàn)類對(duì)象(代理對(duì)象) UserMapper userMapper = sqlSession.getMapper(UserMapper.class); System.out.println("userMapper = " +userMapper); // 6. 調(diào)用接口的方法根據(jù)id查詢用戶 User user = userMapper.findUserById(1); System.out.println("user = " + user); // 7. 關(guān)閉會(huì)話,釋放資源。 sqlSession.close(); } }
你會(huì)發(fā)現(xiàn)在這倆個(gè)方法中有很多相似的代碼,每次寫都要重新寫,關(guān)鍵是還沒(méi)有啥軟用,現(xiàn)在來(lái)看看優(yōu)化之后的代碼
package com.vg.test; import com.vg.dao.UserMapper; import com.vg.entity.User; 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 org.junit.After; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.io.InputStream; import java.util.List; /** * 測(cè)試類 */ public class TestUserMapper { private static SqlSessionFactory sqlSessionFactory =null; private SqlSession sqlSession =null; private UserMapper userMapper =null; // 該方法在所有測(cè)試方法執(zhí)行之前執(zhí)行1次 @BeforeClass public static void init() throws Exception { // 1. 通過(guò)Resources類,加載sqlMapConfig.xml,得到文件輸入流對(duì) InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml"); // 2. 實(shí)例化會(huì)話工廠創(chuàng)建類SqlSessionFactoryBuilder對(duì)象 SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); // 3. 根據(jù)字節(jié)輸入流獲取SqlSessionFactory對(duì)象 sqlSessionFactory = builder.build(in); } // 該方法會(huì)在每個(gè)測(cè)試方法執(zhí)行之前執(zhí)行1次 @Before public void before(){ // 4. 獲取SqlSession對(duì)象,等價(jià)連接對(duì)象 // true:事務(wù)自動(dòng)提交,false:不自動(dòng)提交,默認(rèn)值 sqlSession = sqlSessionFactory.openSession(); // 5. 創(chuàng)建接口 實(shí)現(xiàn)類對(duì)象 userMapper = sqlSession.getMapper(UserMapper.class); } /** * 測(cè)試方法:查詢所有學(xué)生 * SqlSessionFactoryBuilder => SqlSessionFactory => SqlSession:相當(dāng)于JDBC中的Connection對(duì)象,提供了操作數(shù)據(jù)庫(kù)的CRUD方法 */ @Test public void testFindAllUsers() throws Exception{ List<User> userList = userMapper.findAllUsers(); for (User user : userList) { System.out.println(user); } } @Test public void testFindUserById()throws Exception{ // 6. 調(diào)用接口的方法根據(jù)id查詢用戶 User user = userMapper.findUserById(1); System.out.println("user = " + user); } @After public void after() { // 7. 關(guān)閉會(huì)話,釋放資源。 sqlSession.close(); } }
這樣子是不是比以前的代碼簡(jiǎn)單起來(lái)了呢?
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于Java實(shí)現(xiàn)PDF文本旋轉(zhuǎn)傾斜
這篇文章主要介紹了基于Java實(shí)現(xiàn)PDF文本旋轉(zhuǎn)傾斜,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05一篇文章帶你入門java算術(shù)運(yùn)算符(加減乘除余,字符連接)
這篇文章主要介紹了Java基本數(shù)據(jù)類型和運(yùn)算符,結(jié)合實(shí)例形式詳細(xì)分析了java基本數(shù)據(jù)類型、數(shù)據(jù)類型轉(zhuǎn)換、算術(shù)運(yùn)算符、邏輯運(yùn)算符等相關(guān)原理與操作技巧,需要的朋友可以參考下2021-08-08一文教會(huì)你如何搭建vue+springboot項(xiàng)目
最近在搗鼓?SpringBoot?與?Vue?整合的項(xiàng)目,所以下面這篇文章主要給大家介紹了關(guān)于如何通過(guò)一篇文章教會(huì)你搭建vue+springboot項(xiàng)目,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05Java實(shí)現(xiàn)Excel表單控件的添加與刪除
本文通過(guò)Java代碼示例介紹如何在Excel表格中添加表單控件,包括文本框、單選按鈕、復(fù)選框、組合框、微調(diào)按鈕等,以及如何刪除Excel中的指定表單控件,需要的可以參考一下2022-05-05Java修改maven的默認(rèn)jdk版本為1.7的方法
這篇文章主要介紹了Java修改maven的默認(rèn)jdk版本為1.7的方法,需要的朋友可以參考下2018-02-02MyBatisPlus批量添加的優(yōu)化與報(bào)錯(cuò)解決
MybatisPlus是一個(gè)高效的java持久層框架,它在Mybatis的基礎(chǔ)上增加了一些便捷的功能,提供了更加易用的API,可以大幅度提高開發(fā)效率,這篇文章主要給大家介紹了關(guān)于MyBatisPlus批量添加的優(yōu)化與報(bào)錯(cuò)解決的相關(guān)資料,需要的朋友可以參考下2023-05-05