Mybatis結(jié)果集映射與生命周期詳細(xì)介紹
一、ResultMap結(jié)果集映射
1、設(shè)計(jì)思想
對(duì)簡(jiǎn)單的語(yǔ)句做到零配置,對(duì)于復(fù)雜一點(diǎn)的語(yǔ)句,只需要描述語(yǔ)句之間的關(guān)系就行了
2、resultMap的應(yīng)用場(chǎng)景
下面這個(gè)是我的數(shù)據(jù)庫(kù)表
然后這是我們對(duì)應(yīng)的Java實(shí)體類(lèi)User2,除了有參構(gòu)造外,它還定義了一個(gè)無(wú)參構(gòu)造,而且用戶(hù)id字段為userId,與數(shù)據(jù)庫(kù)表中的id不一致
我們?cè)趫?zhí)行查詢(xún)方法后可以發(fā)現(xiàn),實(shí)體類(lèi)中的userId和數(shù)據(jù)庫(kù)表中的id字段沒(méi)有辦法被自動(dòng)關(guān)聯(lián),所以查出來(lái)的結(jié)果中,userId字段是空
所以,為了解決這種問(wèn)題,我們就需要用到resultMap結(jié)果集映射(當(dāng)然,使用as關(guān)鍵字給字段取一個(gè)別名也可以解決此問(wèn)題)
select id as userId,name,sex,age from t_decade_user;
- 首先我們需要在SQL映射文件中定義一個(gè)結(jié)果集映射resultMap,在里面定義一下實(shí)體類(lèi)屬性字段和數(shù)據(jù)庫(kù)表字段的映射關(guān)系,property為實(shí)體類(lèi)中的屬性名,column為數(shù)據(jù)庫(kù)表中的字段名
- 然后在具體查詢(xún)語(yǔ)句處,將原來(lái)的resultType替換成resultMap,并在此處引用我們之前定義的結(jié)果集映射
<?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>
我們?cè)诮涌陬?lèi)中添加一個(gè)注解@Param,這樣就可以避免參數(shù)綁定報(bào)錯(cuò)的問(wèn)題(只有一個(gè)入?yún)r(shí),不會(huì)出現(xiàn)這種錯(cuò)誤)
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); }
最后寫(xiě)一個(gè)測(cè)試方法
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對(duì)象 SqlSession sqlSession = MybatisUtils.getSqlSession(); try { UserMapper userDao = sqlSession.getMapper(UserMapper.class); List<User2> userList = userDao.getUserInfoById("005", "劉亦菲"); // 循環(huán)輸出查詢(xún)到的user信息 userList.forEach(System.out::println); } catch (Exception e) { e.printStackTrace(); } finally { // 關(guān)閉sqlSession sqlSession.close(); } } }
運(yùn)行結(jié)果如下
二、生命周期和作用域
1、SqlSessionFactoryBuilder:用于創(chuàng)建SqlSessionFactory
這個(gè)類(lèi)可以被實(shí)例化、使用和丟棄,一旦創(chuàng)建了 SqlSessionFactory,就不再需要它了
SqlSessionFactoryBuilder 實(shí)例的最佳作用域是方法作用域(也就是局部方法變量)
2、SqlSessionFactory:可以想象成數(shù)據(jù)庫(kù)連接池
SqlSessionFactory 一旦被創(chuàng)建就應(yīng)該在應(yīng)用的運(yùn)行期間一直存在
沒(méi)有任何理由丟棄它或重新創(chuàng)建另一個(gè)實(shí)例,可以使用單例模式實(shí)現(xiàn),SqlSessionFactory 的最佳作用域是應(yīng)用作用域,即Application
3、SqlSession:可以看作連接到數(shù)據(jù)庫(kù)連接池的一個(gè)請(qǐng)求
每個(gè)線(xiàn)程都應(yīng)該有它自己的 SqlSession 實(shí)例,它的實(shí)例不是線(xiàn)程安全的,不能被共享
它的最佳的作用域是請(qǐng)求或方法作用域
用完之后需要關(guān)閉,否則資源會(huì)被占用
到此這篇關(guān)于Mybatis結(jié)果集映射與生命周期詳細(xì)介紹的文章就介紹到這了,更多相關(guān)Mybatis結(jié)果集映射內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring boot springjpa 支持多個(gè)數(shù)據(jù)源的實(shí)例代碼
這篇文章主要介紹了spring boot springjpa 支持多個(gè)數(shù)據(jù)源的實(shí)例代碼,需要的朋友可以參考下2018-04-04Java中的復(fù)合數(shù)據(jù)類(lèi)型
這篇文章主要介紹了Java中的復(fù)合數(shù)據(jù)類(lèi)型,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Spring boot學(xué)習(xí)教程之快速入門(mén)篇
這篇文章主要給大家介紹了關(guān)于Spring boot的相關(guān)資料,本文屬于基礎(chǔ)入門(mén)教程,對(duì)各位學(xué)習(xí)Spring boot的新手們具有一定的參考學(xué)習(xí)價(jià)值,,要的朋友們下面來(lái)一起看看吧。2017-04-04java基礎(chǔ)-給出一個(gè)隨機(jī)字符串,判斷有多少字母?多少數(shù)字?
這篇文章主要介紹了java基礎(chǔ)-給出一個(gè)隨機(jī)字符串,判斷有多少字母?多少數(shù)字?文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04詳解使用Jenkins部署Spring Boot項(xiàng)目
這篇文章主要介紹了詳解使用Jenkins部署Spring Boot,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11關(guān)于Mybatis-Plus?Wrapper是否應(yīng)該出現(xiàn)在Servcie類(lèi)中
最近在做代碼重構(gòu),代碼工程采用了Controller/Service/Dao分層架構(gòu),Dao層使用了Mybatis-Plus框架,本文帶領(lǐng)大家學(xué)習(xí)Mybatis-Plus?Wrapper應(yīng)該出現(xiàn)在Servcie類(lèi)中嗎,需要的朋友可以參考下2023-05-05