1. 程式人生 > 程式設計 >Mybatis如何使用註解優化程式碼

Mybatis如何使用註解優化程式碼

entity層程式碼不變,因為是優化,所以在dao層新增了一個通過id查詢使用者的功能,現在來演示一下優化前後的程式碼對比,希望你們喜歡

entity層程式碼不變,dao層中的UserMapper中新增一個方法

/**
* 根據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中使用沒有優化的程式碼展示

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;

/**
 * 測試類
 */
public class TestUserMapper {

	/**
	 * 測試方法:查詢所有學生
	 * SqlSessionFactoryBuilder => SqlSessionFactory => SqlSession:相當於JDBC中的Connection物件,提供了操作資料庫的CRUD方法
	 */
	@Test
	public void testFindAllUsers()throws Exception{
		// 1. 通過Resources類,載入sqlMapConfig.xml,得到檔案輸入流物件
		// Resources類作用:專門讀取src目錄下的資原始檔
		InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml");
		// 2. 例項化會話工廠建立類SqlSessionFactoryBuilder
		SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
		// 3. 通過會話工廠建立類,讀取上面的輸入流,得到會話工廠SqlSessionFactory類
		SqlSessionFactory sqlSessionFactory = builder.build(in);
		// 4. 使用SqlSessionFactory物件,建立SqlSession物件
		// a) 它相當於JDBC中的Connection物件,提供了操作資料庫的CRUD方法
		// b) 它提供了一個getMapper()方法,獲取介面的實現物件。
		SqlSession sqlSession = sqlSessionFactory.openSession();

		// 5. 獲取介面 UserMapper 實現類物件(代理物件)
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		System.out.println("userMapper = " +userMapper);
		// 6. 執行資料庫的查詢操作,輸出使用者資訊
		List<User> userList = userMapper.findAllUsers();
		for (User user : userList) {
			System.out.println(user);
		}
		// 7. 關閉會話,釋放資源。
		sqlSession.close();
	}
	@Test
	public void testFindUserById()throws Exception{
		// 1. 通過Resources類,載入sqlMapConfig.xml,得到檔案輸入流物件
		// Resources類作用:專門讀取src目錄下的資原始檔
		InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml");
		// 2. 例項化會話工廠建立類SqlSessionFactoryBuilder
		SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
		// 3. 通過會話工廠建立類,讀取上面的輸入流,得到會話工廠SqlSessionFactory類
		SqlSessionFactory sqlSessionFactory = builder.build(in);
		// 4. 使用SqlSessionFactory物件,建立SqlSession物件
		// a) 它相當於JDBC中的Connection物件,提供了操作資料庫的CRUD方法
		// b) 它提供了一個getMapper()方法,獲取介面的實現物件。
		SqlSession sqlSession = sqlSessionFactory.openSession();

		// 5. 獲取介面 UserMapper 實現類物件(代理物件)
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		System.out.println("userMapper = " +userMapper);
		// 6. 呼叫介面的方法根據id查詢使用者
		User user = userMapper.findUserById(1);
		System.out.println("user = " + user);
		// 7. 關閉會話,釋放資源。
		sqlSession.close();
	}
}

你會發現在這倆個方法中有很多相似的程式碼,每次寫都要重新寫,關鍵是還沒有啥軟用,現在來看看優化之後的程式碼

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;

/**
 * 測試類
 */
public class TestUserMapper {
	private static SqlSessionFactory sqlSessionFactory =null;
	private SqlSession sqlSession =null;
	private UserMapper userMapper =null;

	// 該方法在所有測試方法執行之前執行1次
	@BeforeClass
	public static void init() throws Exception {
		// 1. 通過Resources類,載入sqlMapConfig.xml,得到檔案輸入流對
		InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml");
		// 2. 例項化會話工廠建立類SqlSessionFactoryBuilder物件
		SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
		// 3. 根據位元組輸入流獲取SqlSessionFactory物件
		sqlSessionFactory = builder.build(in);
	}
	// 該方法會在每個測試方法執行之前執行1次
	@Before
	public void before(){
		// 4. 獲取SqlSession物件,等價連線物件
		// true:事務自動提交,false:不自動提交,預設值
		sqlSession = sqlSessionFactory.openSession();
		// 5. 建立介面 實現類物件
		 userMapper = sqlSession.getMapper(UserMapper.class);

	}

	/**
	 * 測試方法:查詢所有學生
	 * SqlSessionFactoryBuilder => SqlSessionFactory => SqlSession:相當於JDBC中的Connection物件,提供了操作資料庫的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. 呼叫介面的方法根據id查詢使用者
		User user = userMapper.findUserById(1);
		System.out.println("user = " + user);

	}

	@After
	public void after() {
		// 7. 關閉會話,釋放資源。

		sqlSession.close();
	}
}

這樣子是不是比以前的程式碼簡單起來了呢?

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。