MyBatis中的表關(guān)聯(lián)查詢實(shí)現(xiàn)示例
Mybatis中的一對(duì)多對(duì)象關(guān)聯(lián)查詢查詢
模擬情景,商品與商品詳情:一件商品可以對(duì)應(yīng)多個(gè)商品詳情信息,即從商品➡商品詳情方向看,屬于一對(duì)多。 在一對(duì)多關(guān)系中,需要在屬于一的一方的實(shí)體類中添加多的一方的集合,一般為List<>類型
//(省去了get和set的方法)
public class Goods {
private Integer goodsId ;
private String title ;
private String subTitle ;
private Float originalCost ;
private Float currentPrice ;
private Float discount ;
private Integer isFreeDelivery ;
private Integer categoryId ;
//在一對(duì)多關(guān)系中,在一方添加多的一方的集合
private List<GoodsDetail> goodsDetailLists ;
}
在"一方"實(shí)體類對(duì)應(yīng)的xml 文件中,添加配置信息
<!-- OneToMany對(duì)象關(guān)聯(lián)查詢
resultMap可用于說明一對(duì)多或者多對(duì)一的映射邏輯
id 是resultMap屬性引用的標(biāo)志
type 指向One的實(shí)體(Goods)
-->
<resultMap id="rmGoods1" type="com.imooc.mybatis.entity.Goods">
<!-- 映射goods對(duì)象的主鍵到goods_id字段-->
<id column="goods_id" property="goodsId"></id>
<!--
collection的含義是,在
sql語句得到結(jié)果后,對(duì)所有Goods對(duì)象遍歷得到goods_id字段值,
并代入到goodsDetail命名空間的selectByGoodsId的sql中執(zhí)行查詢
將得到的“商品詳情”集合賦值給goodsDetailsList對(duì)象
-->
<collection property="goodsDetailLists" select="goodsDetail.selectByGoodsId"
column="goods_id"></collection>
</resultMap>
<select id="selectOneToMany" resultMap="rmGoods1">
select * from t_goods limit 0 , 1
</select>
在“多方”對(duì)應(yīng)的xml文件中添加
<mapper namespace="goodsDetail">
<select id="selectByGoodsId" parameterType="Integer"
resultType="com.imooc.mybatis.entity.GoodsDetail">
select * from t_goods_detail where goods_id = #{value}
</select>
</mapper>
至此,關(guān)于商品到商品詳情的一對(duì)多查詢配置就完成了。
測(cè)試
//OneToMany
@Test
public void selectOneToMany(){
SqlSession sqlSession = null ;
try{
sqlSession = MybatisUtils.openSession() ;
List<Goods> list = sqlSession.selectList("goods.selectOneToMany");
for (Goods g : list){
//輸出商品和該商品的詳情信息數(shù)量
System.out.println(g.getTitle() + ":" + g.getGoodsDetailLists().size());
}
}catch (Exception e){
e.printStackTrace();
}finally {
MybatisUtils.closeSession(sqlSession);
}
}
Mybatis多對(duì)一對(duì)象關(guān)聯(lián)查詢
在上訴情景中,商品詳情➡商品即為多對(duì)一的關(guān)系
在多對(duì)一關(guān)系中,需要在多的一方的實(shí)體類中添加一的一方的實(shí)體對(duì)象
public class GoodsDetail {
private Integer gdId ;
private Integer goodsId ;
private String gdPicUrl ;
private Integer gdOrder ;
//多對(duì)一:在多的一方添加一的一方的實(shí)體
private Goods goods ;
}
在多的一方xml文件中添加
<!-- 多對(duì)一關(guān)系-->
<resultMap id="rmGoodsDetail" type="com.imooc.mybatis.entity.GoodsDetail">
<id column="gd_id" property="gdId"></id>
<result column="goods_id" property="goodsId"></result>
<!-- goods.selectById 為goods.xml根據(jù)主鍵id查找goods信息。-->
<association property="goods" select="goods.selectById" column="goods_id"></association>
</resultMap>
<select id="selectManyToOne" resultMap="rmGoodsDetail">
select * from t_goods_detail limit 0 , 1
</select>
測(cè)試
/**
* 多對(duì)一對(duì)象關(guān)聯(lián)映射
* */
@Test
public void selectManyToOne(){
SqlSession sqlSession = null ;
try{
sqlSession = MybatisUtils.openSession() ;
List<GoodsDetail> list = sqlSession.selectList("goodsDetail.selectManyToOne");
for (GoodsDetail gd : list){
System.out.println(gd.getGdPicUrl() + ":" + gd.getGoods().getTitle());
}
}catch (Exception e){
e.printStackTrace();
}finally {
MybatisUtils.closeSession(sqlSession);
}
}
到此這篇關(guān)于MyBatis中的表關(guān)聯(lián)查詢實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)MyBatis 表關(guān)聯(lián)查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
jdk環(huán)境變量配置切換jdk版本及安裝jdk后環(huán)境變量不生效問題解決辦法
這篇文章主要介紹了jdk環(huán)境變量配置切換jdk版本及安裝jdk后環(huán)境變量不生效問題解決辦法,包括配置JAVA_HOME、Path和CLASSPATH,以及如何驗(yàn)證配置是否成功,文章還講解了如何切換JDK版本,并解決了安裝新JDK后環(huán)境變量配置不生效的問題,需要的朋友可以參考下2024-12-12
基于Java將Excel科學(xué)計(jì)數(shù)法解析成數(shù)字
這篇文章主要介紹了基于Java將Excel科學(xué)計(jì)數(shù)法解析成數(shù)字,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
SpringBoot聲明式事務(wù)的簡(jiǎn)單運(yùn)用說明
這篇文章主要介紹了SpringBoot聲明式事務(wù)的簡(jiǎn)單運(yùn)用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Java詳細(xì)分析講解自動(dòng)裝箱自動(dòng)拆箱與Integer緩存的使用
裝箱就是把基本類型轉(zhuǎn)換成包裝類,拆箱就是把包裝類轉(zhuǎn)換成基本類型,下面這篇文章主要給大家介紹Java中自動(dòng)裝箱、自動(dòng)拆箱與Integer緩存,需要的朋友可以參考下2022-04-04
解決StringBuffer和StringBuilder的擴(kuò)容問題
這篇文章主要介紹了解決StringBuffer和StringBuilder的擴(kuò)容問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
基于CopyOnWriteArrayList并發(fā)容器(實(shí)例講解)
下面小編就為大家?guī)硪黄贑opyOnWriteArrayList并發(fā)容器(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11
Java中關(guān)于字典樹的算法實(shí)現(xiàn)
字典樹,又稱單詞查找樹,Trie樹,是一種樹形結(jié)構(gòu),哈希表的一個(gè)變種。用于統(tǒng)計(jì),排序和保存大量的字符串,本文針對(duì)字典樹給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值2021-09-09
Spring Security獲取用戶認(rèn)證信息的實(shí)現(xiàn)流程
Spring Security是一個(gè)能夠?yàn)榛赟pring的企業(yè)應(yīng)用系統(tǒng)提供聲明式的安全訪問控制解決方案的安全框架。它提供了一組可以在Spring應(yīng)用上下文中配置的Bean,充分利用了Spring IoC,DI和AOP功能,為應(yīng)用系統(tǒng)提供聲明式的安全訪問控制功能2022-12-12

