Mybatis結果集映射與生命周期詳細介紹
一、ResultMap結果集映射
1、設計思想
對簡單的語句做到零配置,對於復雜一點的語句,隻需要描述語句之間的關系就行瞭
2、resultMap的應用場景
下面這個是我的數據庫表
然後這是我們對應的Java實體類User2,除瞭有參構造外,它還定義瞭一個無參構造,而且用戶id字段為userId,與數據庫表中的id不一致
我們在執行查詢方法後可以發現,實體類中的userId和數據庫表中的id字段沒有辦法被自動關聯,所以查出來的結果中,userId字段是空
所以,為瞭解決這種問題,我們就需要用到resultMap結果集映射(當然,使用as關鍵字給字段取一個別名也可以解決此問題)
select id as userId,name,sex,age from t_decade_user;
- 首先我們需要在SQL映射文件中定義一個結果集映射resultMap,在裡面定義一下實體類屬性字段和數據庫表字段的映射關系,property為實體類中的屬性名,column為數據庫表中的字段名
- 然後在具體查詢語句處,將原來的resultType替換成resultMap,並在此處引用我們之前定義的結果集映射
<?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="com.decade.mapper.UserMapper"> <resultMap id="userInfo" type="com.decade.entity.User2"> <result property="userId" column="id" jdbcType="VARCHAR"/> <result property="name" column="name" jdbcType="VARCHAR"/> <result property="sex" column="sex" jdbcType="VARCHAR"/> <result property="age" column="age" jdbcType="INTEGER"/> </resultMap> <select id="getUserInfoById" resultMap="userInfo"> select * from t_decade_user where id = #{userId} and name = #{name}; </select> </mapper>
我們在接口類中添加一個註解@Param,這樣就可以避免參數綁定報錯的問題(隻有一個入參時,不會出現這種錯誤)
package com.decade.mapper; import com.decade.entity.User2; import org.apache.ibatis.annotations.Param; import java.util.List; public interface UserMapper { List<User2> getUserInfoById(@Param("userId") String userId, @Param("name") String name); }
最後寫一個測試方法
import com.decade.entity.User2; import com.decade.mapper.UserMapper; import com.decade.utils.MybatisUtils; import org.apache.ibatis.session.SqlSession; import org.junit.Test; import java.util.List; public class UserDaoTest { @Test public void test2() { // 第一步:獲取sqlSession對象 SqlSession sqlSession = MybatisUtils.getSqlSession(); try { UserMapper userDao = sqlSession.getMapper(UserMapper.class); List<User2> userList = userDao.getUserInfoById("005", "劉亦菲"); // 循環輸出查詢到的user信息 userList.forEach(System.out::println); } catch (Exception e) { e.printStackTrace(); } finally { // 關閉sqlSession sqlSession.close(); } } }
運行結果如下
二、生命周期和作用域
1、SqlSessionFactoryBuilder:用於創建SqlSessionFactory
這個類可以被實例化、使用和丟棄,一旦創建瞭 SqlSessionFactory,就不再需要它瞭
SqlSessionFactoryBuilder 實例的最佳作用域是方法作用域(也就是局部方法變量)
2、SqlSessionFactory:可以想象成數據庫連接池
SqlSessionFactory 一旦被創建就應該在應用的運行期間一直存在
沒有任何理由丟棄它或重新創建另一個實例,可以使用單例模式實現,SqlSessionFactory 的最佳作用域是應用作用域,即Application
3、SqlSession:可以看作連接到數據庫連接池的一個請求
每個線程都應該有它自己的 SqlSession 實例,它的實例不是線程安全的,不能被共享
它的最佳的作用域是請求或方法作用域
用完之後需要關閉,否則資源會被占用
到此這篇關於Mybatis結果集映射與生命周期詳細介紹的文章就介紹到這瞭,更多相關Mybatis結果集映射內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- MyBatis延遲加載策略深入探究
- 解讀Mapper與Mapper.xml文件之間匹配的問題
- mybatis使用resultMap獲取不到值的解決方案
- Java Mybatis框架多表操作與註解開發詳解分析
- Spring整合Mybatis的全過程