中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis結果集映射與生命周期源碼分析

發布時間:2022-10-12 10:34:41 來源:億速云 閱讀:97 作者:iii 欄目:開發技術

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

    一、ResultMap結果集映射

    1、設計思想

    對簡單的語句做到零配置,對于復雜一點的語句,只需要描述語句之間的關系就行了

    2、resultMap的應用場景

    下面這個是我的數據庫表

    Mybatis結果集映射與生命周期源碼分析

    然后這是我們對應的Java實體類User2,除了有參構造外,它還定義了一個無參構造,而且用戶id字段為userId,與數據庫表中的id不一致

    Mybatis結果集映射與生命周期源碼分析

    我們在執行查詢方法后可以發現,實體類中的userId和數據庫表中的id字段沒有辦法被自動關聯,所以查出來的結果中,userId字段是空

    Mybatis結果集映射與生命周期源碼分析

    所以,為了解決這種問題,我們就需要用到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();
            }
        }
    }

    運行結果如下

    Mybatis結果集映射與生命周期源碼分析

    二、生命周期和作用域

    1、SqlSessionFactoryBuilder:用于創建SqlSessionFactory

    這個類可以被實例化、使用和丟棄,一旦創建了 SqlSessionFactory,就不再需要它了

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

    2、SqlSessionFactory:可以想象成數據庫連接池

    SqlSessionFactory 一旦被創建就應該在應用的運行期間一直存在

    沒有任何理由丟棄它或重新創建另一個實例,可以使用單例模式實現,SqlSessionFactory 的最佳作用域是應用作用域,即Application

    3、SqlSession:可以看作連接到數據庫連接池的一個請求

    每個線程都應該有它自己的 SqlSession 實例,它的實例不是線程安全的,不能被共享

    它的最佳的作用域是請求或方法作用域

    用完之后需要關閉,否則資源會被占用

    到此,相信大家對“Mybatis結果集映射與生命周期源碼分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    昌图县| 饶平县| 莱西市| 洪泽县| 壶关县| 丰宁| 贵州省| 永州市| 大姚县| 双鸭山市| 广安市| 淳安县| 白朗县| 伊春市| 射洪县| 宿迁市| 绩溪县| 淮阳县| 甘肃省| 修武县| 安西县| 灵寿县| 平陆县| 巢湖市| 丹阳市| 穆棱市| 安国市| 乌什县| 玉门市| 湘阴县| 呼玛县| 河曲县| 琼结县| 兴安县| 京山县| 包头市| 新宾| 阿克陶县| 忻城县| 岳普湖县| 台中县|