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

Mybatis實(shí)現(xiàn)一對(duì)一查詢映射處理

 更新時(shí)間:2023年08月01日 15:04:18   作者:_GGBond_  
MyBatis是一種流行的Java持久化框架,它提供了靈活而強(qiáng)大的查詢映射功能,本文主要介紹了Mybatis實(shí)現(xiàn)一對(duì)一查詢映射處理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

一、概述

MyBatis是一種流行的Java持久化框架,它提供了靈活而強(qiáng)大的查詢映射功能。在一些復(fù)雜的數(shù)據(jù)模型中,一對(duì)一查詢映射是一種常見(jiàn)的需求。本篇博客將詳細(xì)介紹如何在MyBatis中處理一對(duì)一查詢映射。

二、創(chuàng)建數(shù)據(jù)模型

假設(shè)我們有兩張數(shù)據(jù)表,員工表和部門(mén)表,每個(gè)員工都只屬于一個(gè)部門(mén),我們需要?jiǎng)?chuàng)建對(duì)應(yīng)的Java數(shù)據(jù)模型。

Emp.java

public class Emp {
    private Integer eid;
    private String empName;
    private Integer age;
    private String sex;
    private String email;
    private Dept dept;
    ...
    }

Dept.java

public class Dept {
    private Integer did;
    private String deptName;
    private List<Emp> emps;
    ...
    }

三、 問(wèn)題

現(xiàn)在我們要查詢員工信息以及員工所對(duì)應(yīng)的部門(mén)信息,我們應(yīng)該如何做呢?

四、解決方案

1、方案一:級(jí)聯(lián)方式處理映射關(guān)系

EmpMapper

/**
  * @description:獲取指定員工的信息(包括部門(mén))
  * @author: Hey
  * @date: 2022/7/4 8:58
  * @param: [id]
  * @return: com.ir.mybatis.pojo.Emp
  **/
    Emp getAllEmpAndDept(@Param("eid") Integer eid);

EmpMapper.xml

<resultMap id="title1" type="Emp">
        <id property="eid" column="eid"></id>
        <result property="empName" column="emp_name"></result>
        <result property="age" column="age"></result>
        <result property="sex" column="sex"></result>
        <result property="email" column="email"></result>
        <result property="dept.did" column="did"></result>
        <result property="dept.deptName" column="dept_name"></result>
</resultMap>
    <select id="getAllEmpAndDept" resultMap="title1">
        select * from t_emp left join t_dept on t_emp.did = t_dept .did where t_emp.eid = #{eid}
    </select>

ResultTest

/**
? ? ?* @description:獲取指定員工的信息(包括部門(mén))
? ? ?* @author: Hey
? ? ?* @date: 2022/7/4 8:56
? ? ?* @param: []
? ? ?* @return: void
? ? ?**/
? ? @Test
? ? public void getAllEmpAndDept(){
? ? ? ? SqlSession sqlSession = SqlSessionUtils.getSqlSession();
? ? ? ? EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
? ? ? ? Emp emp = mapper.getAllEmpAndDept(2);
? ? ? ? System.out.println(emp);//Emp{eid=2, empName='美羊羊', age=32, sex='女', email='123@qq.com'}
? ? }

2、方案二:使用association處理映射關(guān)系

EmpMapper

/**
  * @description:獲取指定員工的信息(包括部門(mén))
  * @author: Hey
  * @date: 2022/7/4 8:58
  * @param: [id]
  * @return: com.ir.mybatis.pojo.Emp
  **/
    Emp getAllEmpAndDept(@Param("eid") Integer eid);

EmpMapper.xml

? ?<resultMap id="title1" type="Emp">
? ? ? ? <id property="eid" column="eid"></id>
? ? ? ? <result property="empName" column="emp_name"></result>
? ? ? ? <result property="age" column="age"></result>
? ? ? ? <result property="sex" column="sex"></result>
? ? ? ? <result property="email" column="email"></result>
? ? ? ?<!--
? ? ? ? ? ? association:處理多對(duì)一的映射關(guān)系
? ? ? ? ? ? property:需要處理多對(duì)的映射關(guān)系的屬性名
? ? ? ? ? ? javaType:該屬性的類(lèi)型
? ? ? ? ? ? 過(guò)程:通過(guò)javaType,運(yùn)用反射,確定其所有屬性,再將column一一準(zhǔn)確賦值
? ? ? ? ? ? 給指定的屬性,這樣就得出了一個(gè)實(shí)體類(lèi)對(duì)象,再將這個(gè)對(duì)象賦值給property
? ? ? ? ? ? 中的對(duì)象名
? ? ? ? -->
? ? ? ? <association property="dept" javaType="Dept">
? ? ? ? ? ? <id property="did" column="did"></id>
? ? ? ? ? ? <result property="deptName" column="dept_name"></result>
? ? ? ? </association>
? ? </resultMap>
? ? <select id="getAllEmpAndDept" resultMap="title1">
? ? ? ? select * from t_emp left join t_dept on t_emp.did = t_dept .did where t_emp.eid = #{eid}
? ? </select>

ResultTest

/**
? ? ?* @description:獲取指定員工的信息(包括部門(mén))
? ? ?* @author: Hey
? ? ?* @date: 2022/7/4 8:56
? ? ?* @param: []
? ? ?* @return: void
? ? ?**/
? ? @Test
? ? public void getAllEmpAndDept(){
? ? ? ? SqlSession sqlSession = SqlSessionUtils.getSqlSession();
? ? ? ? EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
? ? ? ? Emp emp = mapper.getAllEmpAndDept(3);
? ? ? ? System.out.println(emp);//Emp{eid=3, empName='懶洋洋', age=34, sex='男', email='123@qq.com'}
? ? }

3、方案三:分步查詢

mybatis-config.xml

?<!--設(shè)置MyBatis的全局配置-->
? ? <settings>
? ? ? ? <!--將_自動(dòng)映射為駝峰,emp_name:empName-->
? ? ? ? <setting name="mapUnderscoreToCamelCase" value="true"/>
? ? ? ? ?<!--開(kāi)啟延遲加載-->
? ? ? ? <setting name="lazyLoadingEnabled" value="true"/>
? ? </settings>

EmpMapper

/**
     * @description:通過(guò)分步查詢查詢員工以及員工所對(duì)應(yīng)的部門(mén)信息
     *              分步查詢第一步:查詢員工信息
     * @author: Hey 
     * @date: 2022/7/4 9:41
     * @param: [eid]
     * @return: com.ir.mybatis.pojo.Emp
     **/
    Emp getEmpAndDeptByStepOne(@Param("eid") Integer eid);

EmpMapper.xml

<resultMap id="empAndDeptByStepResultMap" type="Emp">
? ? ? ? <id property="eid" column="eid"></id>
? ? ? ? <result property="empName" column="emp_name"></result>
? ? ? ? <result property="age" column="age"></result>
? ? ? ? <result property="sex" column="sex"></result>
? ? ? ? <result property="email" column="email"></result>
? ? ? ? <!--
? ? ? ? ? ? select:設(shè)置分步查詢的sql的唯一標(biāo)識(shí)(namespace.SQLId或mapper接口的全類(lèi)名.方法名)
? ? ? ? ? ? column:設(shè)置分布查詢的條件:根據(jù)員工的部門(mén)的did去查詢?cè)搯T工所屬部門(mén)的信息
? ? ? ? ? ? fetchType:當(dāng)開(kāi)啟了全局的延遲加載之后,可通過(guò)此屬性手動(dòng)控制延遲加載的效果
? ? ? ? ? ? fetchType="lazy|eager":lazy表示延遲加載,eager表示立即加載
? ? ? ? -->
? ? ? ? <association property="dept"
? ? ? ? ? ? ? ? ? ? ?select="com.ir.mybatis.mapper.DeptMapper.getEmpAndDeptByStepTwo"
? ? ? ? ? ? ? ? ? ? ?column="did"
? ? ? ? ? ? ? ? ? ? ?>
? ? ? ? </association>
</resultMap>
? ? <!--Emp getEmpAndDeptByStepOne(@Param("eid") Integer eid);-->
? ? <select id="getEmpAndDeptByStepOne" resultMap="empAndDeptByStepResultMap">
? ? ? ? select * from t_emp where eid = #{eid}
? ? </select>

DeptMapper

/**
     * @description:通過(guò)分步查詢查詢部門(mén)以及部門(mén)中所有的員工信息
     *              分步查詢第二步:根據(jù)did查詢員工信息
     * @author: Hey 
     * @date: 2022/7/4 9:42
     * @param: [did]
     * @return: java.util.List<com.ir.mybatis.pojo.Emp>
     **/
    List<Emp> getDeptAndEmpByStepTwo(@Param("did") Integer did);

DeptMapper.xml

 <!--Dept getEmpAndDeptByStepTwo(@Param("did") Integer did);-->
    <select id="getEmpAndDeptByStepTwo" resultType="Dept">
        select * from t_dept where did = #{did}
    </select>

ResultTest

/**
? ? ?* @description:通過(guò)分步查詢查詢部門(mén)以及部門(mén)中所有的員工信息
? ? ?* @author: Hey?
? ? ?* @date: 2022/7/4 9:53
? ? ?* @param: []
? ? ?* @return: void
? ? ?**/
? ? @Test
? ? public void testGetEmpAndDeptByStep(){
? ? ? ? SqlSession sqlSession = SqlSessionUtils.getSqlSession();
? ? ? ? EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
? ? ? ? Emp emp = mapper.getEmpAndDeptByStepOne(3);
? ? ? ? System.out.println(emp);//Emp{eid=3, empName='懶洋洋', age=34, sex='男', email='123@qq.com'}
? ? }

到此這篇關(guān)于Mybatis實(shí)現(xiàn)一對(duì)一查詢映射處理的文章就介紹到這了,更多相關(guān)Mybatis 查詢映射內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java將String字符串帶括號(hào)轉(zhuǎn)成List的簡(jiǎn)單方法

    Java將String字符串帶括號(hào)轉(zhuǎn)成List的簡(jiǎn)單方法

    Java中我們有時(shí)需要對(duì)現(xiàn)有的字符串進(jìn)行切割并轉(zhuǎn)化成一個(gè)List集合,這篇文章主要給大家介紹了關(guān)于Java將String字符串帶括號(hào)轉(zhuǎn)成List的簡(jiǎn)單方法,需要的朋友可以參考下
    2023-03-03
  • win10安裝JDK14.0.2的詳細(xì)安裝過(guò)程

    win10安裝JDK14.0.2的詳細(xì)安裝過(guò)程

    這篇文章主要介紹了win10安裝JDK14.0.2的詳細(xì)安裝過(guò)程的相關(guān)資料,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • RabbitMq報(bào)錯(cuò)reply-code=406 reply-text=PRECONDITION_FAILED解決

    RabbitMq報(bào)錯(cuò)reply-code=406 reply-text=PRECONDITION_FAILED

    這篇文章主要為大家介紹了RabbitMq報(bào)錯(cuò)reply-code=406 reply-text=PRECONDITION_FAILED分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • java實(shí)現(xiàn)人工智能化屏幕監(jiān)控窗口

    java實(shí)現(xiàn)人工智能化屏幕監(jiān)控窗口

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)人工智能化屏幕監(jiān)控窗口,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • Java單例模式繼承覆蓋多態(tài)原理詳解

    Java單例模式繼承覆蓋多態(tài)原理詳解

    這篇文章主要介紹了Java單例模式繼承覆蓋多態(tài)原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java基礎(chǔ):流Stream詳解

    Java基礎(chǔ):流Stream詳解

    Stream流是數(shù)據(jù)渠道,用于操作數(shù)據(jù)源(集合、數(shù)組等)所生成的元素序列。這篇文章主要介紹了Java8新特性Stream流的相關(guān)資料,需要的朋友參考下吧
    2021-09-09
  • Mybatis如何使用動(dòng)態(tài)語(yǔ)句實(shí)現(xiàn)批量刪除(delete結(jié)合foreach)

    Mybatis如何使用動(dòng)態(tài)語(yǔ)句實(shí)現(xiàn)批量刪除(delete結(jié)合foreach)

    這篇文章主要介紹了Mybatis如何使用動(dòng)態(tài)語(yǔ)句實(shí)現(xiàn)批量刪除(delete結(jié)合foreach),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Spring事務(wù)@Transactional注解四種不生效案例場(chǎng)景分析

    Spring事務(wù)@Transactional注解四種不生效案例場(chǎng)景分析

    這篇文章主要為大家介紹了Spring事務(wù)@Transactional注解四種不生效的案例場(chǎng)景示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • springBoot 整合ModBus TCP的詳細(xì)過(guò)程

    springBoot 整合ModBus TCP的詳細(xì)過(guò)程

    ModBus是一種串行通信協(xié)議,用于從儀器和控制設(shè)備傳輸信號(hào)到主控制器或數(shù)據(jù)采集系統(tǒng),它分為主站和從站,主站獲取和編寫(xiě)數(shù)據(jù),從站則是設(shè)備,本文給大家介紹springBoot 整合ModBus TCP的詳細(xì)過(guò)程,感興趣的朋友一起看看吧
    2025-01-01
  • 利用Java寫(xiě)一個(gè)學(xué)生管理系統(tǒng)

    利用Java寫(xiě)一個(gè)學(xué)生管理系統(tǒng)

    今天這篇文章就給給大家分享利用Java寫(xiě)一個(gè)學(xué)生管理系統(tǒng)吧,先寫(xiě)一個(gè)簡(jiǎn)單的用List來(lái)實(shí)現(xiàn)學(xué)生管理系統(tǒng):
    2021-09-09

最新評(píng)論