色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MyBatis中的表關(guān)聯(lián)查詢實(shí)現(xiàn)示例

瀏覽:26日期:2023-10-20 12:12:30
Mybatis中的一對(duì)多對(duì)象關(guān)聯(lián)查詢查詢

模擬情景,商品與商品詳情:一件商品可以對(duì)應(yīng)多個(gè)商品詳情信息,即從商品➡商品詳情方向看,屬于一對(duì)多。 在一對(duì)多關(guān)系中,需要在屬于一的一方的實(shí)體類中添加多的一方的集合,一般為L(zhǎng)ist<>類型

//(省去了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 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 resultMap='rmGoods1'> select * from t_goods limit 0 , 1 </select>

在“多方”對(duì)應(yīng)的xml文件中添加

<mapper namespace='goodsDetail'> <select 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 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 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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 一区二区影院 | 久久久久久久国产精品影院 | 高清波多野结衣一区二区三区 | 日本高清色本在线www游戏 | 成人影院免费观看 | 91久久国产综合精品女同国语 | 一级毛片视频在线 | 91热久久 | 美国一级视频 | 韩国美女爽快一级毛片黄 | 欧洲美女a视频一级毛片 | 国产精品不卡无毒在线观看 | 免费播放国产性色生活片 | 5388国产亚洲欧美在线观看 | 日本三本道 | 精品香蕉99久久久久网站 | 欧美色xx| 精品成人免费一区二区在线播放 | 91精品国产91久久久久青草 | 正在播真实出轨炮对白 | 日韩亚洲欧美一区 | 国产成人亚洲精品2020 | 日本在线免费观看视频 | 99热久久国产精品免费看 | 国产自愉自愉全免费高清 | 久久久久久久久国产 | 一级做a爰片欧美一区 | 国产一区亚洲二区 | 国产菲菲视频在线观看 | 视频一区 欧美 | 国产精品日韩欧美一区二区三区 | 亚洲黄a | 亚洲黄色免费网址 | 国产在线视频欧美亚综合 | 亚洲成人一区在线 | 亚洲欧美在线精品一区二区 | 波多野结衣视频免费在线观看 | 国产自在自线午夜精品视频 | 怡红院成人永久免费看 | 毛毛片在线 | 在线看国产视频 |