溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Mybatis結(jié)果集映射與生命周期源碼分析

發(fā)布時(shí)間:2022-10-12 10:34:41 來(lái)源:億速云 閱讀:90 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Mybatis結(jié)果集映射與生命周期源碼分析”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Mybatis結(jié)果集映射與生命周期源碼分析”吧!

    一、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ù)表

    Mybatis結(jié)果集映射與生命周期源碼分析

    然后這是我們對(duì)應(yīng)的Java實(shí)體類User2,除了有參構(gòu)造外,它還定義了一個(gè)無(wú)參構(gòu)造,而且用戶id字段為userId,與數(shù)據(jù)庫(kù)表中的id不一致

    Mybatis結(jié)果集映射與生命周期源碼分析

    我們?cè)趫?zhí)行查詢方法后可以發(fā)現(xiàn),實(shí)體類中的userId和數(shù)據(jù)庫(kù)表中的id字段沒有辦法被自動(dòng)關(guān)聯(lián),所以查出來(lái)的結(jié)果中,userId字段是空

    Mybatis結(jié)果集映射與生命周期源碼分析

    所以,為了解決這種問(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í)體類屬性字段和數(shù)據(jù)庫(kù)表字段的映射關(guān)系,property為實(shí)體類中的屬性名,column為數(shù)據(jù)庫(kù)表中的字段名

    • 然后在具體查詢語(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è)诮涌陬愔刑砑右粋€(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);
    }

    最后寫一個(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)輸出查詢到的user信息
                userList.forEach(System.out::println);
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                // 關(guān)閉sqlSession
                sqlSession.close();
            }
        }
    }

    運(yùn)行結(jié)果如下

    Mybatis結(jié)果集映射與生命周期源碼分析

    二、生命周期和作用域

    1、SqlSessionFactoryBuilder:用于創(chuàng)建SqlSessionFactory

    這個(gè)類可以被實(shí)例化、使用和丟棄,一旦創(chuàng)建了 SqlSessionFactory,就不再需要它了

    SqlSessionFactoryBuilder 實(shí)例的最佳作用域是方法作用域(也就是局部方法變量)

    2、SqlSessionFactory:可以想象成數(shù)據(jù)庫(kù)連接池

    SqlSessionFactory 一旦被創(chuàng)建就應(yīng)該在應(yīng)用的運(yùn)行期間一直存在

    沒有任何理由丟棄它或重新創(chuàng)建另一個(gè)實(shí)例,可以使用單例模式實(shí)現(xiàn),SqlSessionFactory 的最佳作用域是應(yīng)用作用域,即Application

    3、SqlSession:可以看作連接到數(shù)據(jù)庫(kù)連接池的一個(gè)請(qǐng)求

    每個(gè)線程都應(yīng)該有它自己的 SqlSession 實(shí)例,它的實(shí)例不是線程安全的,不能被共享

    它的最佳的作用域是請(qǐng)求或方法作用域

    用完之后需要關(guān)閉,否則資源會(huì)被占用

    到此,相信大家對(duì)“Mybatis結(jié)果集映射與生命周期源碼分析”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI