欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis結(jié)果集映射與生命周期詳細(xì)介紹

 更新時(shí)間:2022年10月10日 17:22:08   作者:Decade0712  
結(jié)果集映射指的是將數(shù)據(jù)表中的字段與實(shí)體類中的屬性關(guān)聯(lián)起來,這樣 MyBatis 就可以根據(jù)查詢到的數(shù)據(jù)來填充實(shí)體對象的屬性,幫助我們完成賦值操作

一、ResultMap結(jié)果集映射

1、設(shè)計(jì)思想

對簡單的語句做到零配置,對于復(fù)雜一點(diǎn)的語句,只需要描述語句之間的關(guān)系就行了

2、resultMap的應(yīng)用場景

下面這個(gè)是我的數(shù)據(jù)庫表

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

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

所以,為了解決這種問題,我們就需要用到resultMap結(jié)果集映射(當(dāng)然,使用as關(guān)鍵字給字段取一個(gè)別名也可以解決此問題)

select id as userId,name,sex,age from t_decade_user;

  • 首先我們需要在SQL映射文件中定義一個(gè)結(jié)果集映射resultMap,在里面定義一下實(shí)體類屬性字段和數(shù)據(jù)庫表字段的映射關(guān)系,property為實(shí)體類中的屬性名,column為數(shù)據(jù)庫表中的字段名
  • 然后在具體查詢語句處,將原來的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>

我們在接口類中添加一個(gè)注解@Param,這樣就可以避免參數(shù)綁定報(bào)錯(cuò)的問題(只有一個(gè)入?yún)r(shí),不會出現(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è)測試方法

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", "劉亦菲");
            // 循環(huá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è)類可以被實(shí)例化、使用和丟棄,一旦創(chuàng)建了 SqlSessionFactory,就不再需要它了

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

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

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

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

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

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

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

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

到此這篇關(guān)于Mybatis結(jié)果集映射與生命周期詳細(xì)介紹的文章就介紹到這了,更多相關(guān)Mybatis結(jié)果集映射內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論