国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

MyBatis中的表關聯查詢實現示例

瀏覽:16日期:2023-10-20 12:12:30
Mybatis中的一對多對象關聯查詢查詢

模擬情景,商品與商品詳情:一件商品可以對應多個商品詳情信息,即從商品➡商品詳情方向看,屬于一對多。 在一對多關系中,需要在屬于一的一方的實體類中添加多的一方的集合,一般為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 ; //在一對多關系中,在一方添加多的一方的集合 private List<GoodsDetail> goodsDetailLists ; }

在'一方'實體類對應的xml 文件中,添加配置信息

<!-- OneToMany對象關聯查詢 resultMap可用于說明一對多或者多對一的映射邏輯 id 是resultMap屬性引用的標志 type 指向One的實體(Goods)--> <resultMap type='com.imooc.mybatis.entity.Goods'><!-- 映射goods對象的主鍵到goods_id字段--> <id column='goods_id' property='goodsId'></id><!-- collection的含義是,在 sql語句得到結果后,對所有Goods對象遍歷得到goods_id字段值, 并代入到goodsDetail命名空間的selectByGoodsId的sql中執行查詢 將得到的“商品詳情”集合賦值給goodsDetailsList對象--> <collection property='goodsDetailLists' select='goodsDetail.selectByGoodsId' column='goods_id'></collection> </resultMap> <select resultMap='rmGoods1'> select * from t_goods limit 0 , 1 </select>

在“多方”對應的xml文件中添加

<mapper namespace='goodsDetail'> <select parameterType='Integer' resultType='com.imooc.mybatis.entity.GoodsDetail'> select * from t_goods_detail where goods_id = #{value} </select></mapper>

至此,關于商品到商品詳情的一對多查詢配置就完成了。

測試

//OneToMany @Test public void selectOneToMany(){ SqlSession sqlSession = null ; try{ sqlSession = MybatisUtils.openSession() ; List<Goods> list = sqlSession.selectList('goods.selectOneToMany'); for (Goods g : list){ //輸出商品和該商品的詳情信息數量System.out.println(g.getTitle() + ':' + g.getGoodsDetailLists().size()); } }catch (Exception e){ e.printStackTrace(); }finally { MybatisUtils.closeSession(sqlSession); } }Mybatis多對一對象關聯查詢

在上訴情景中,商品詳情➡商品即為多對一的關系在多對一關系中,需要在多的一方的實體類中添加一的一方的實體對象

public class GoodsDetail { private Integer gdId ; private Integer goodsId ; private String gdPicUrl ; private Integer gdOrder ; //多對一:在多的一方添加一的一方的實體 private Goods goods ;}

在多的一方xml文件中添加

<!-- 多對一關系--> <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根據主鍵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>測試

/** * 多對一對象關聯映射 * */ @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); } }

到此這篇關于MyBatis中的表關聯查詢實現示例的文章就介紹到這了,更多相關MyBatis 表關聯查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 日韩在线视频免费不卡一区 | 国产精品美女久久福利网站 | 成年人网站在线观看视频 | 欧美激情免费观看一区 | 国产成人精品免费午夜 | 狠狠色综合久久婷婷 | 精品国产综合区久久久久久 | 亚洲第一在线播放 | 国产一区二区日韩欧美在线 | 伊人黄色片 | 久久亚洲在线 | 国产国模福利视频 | 精品视频久久久久 | 日本亚洲视频 | 一级做a爰片性色毛片小说 一级做a爰片性色毛片中国 | 成人免费毛片观看 | 欧美一区二区三区精品 | jizzjizz成熟丰满舒服 | 一级片免费观看 | 东莞a级毛片 | 日本一区二区三区在线 视频观看免费 | 国产成人tv在线观看 | 国产成人香蕉久久久久 | 综合图片亚洲网友自拍10p | 国产免费亚洲 | 成人午夜看片在线观看 | 91香蕉网| 免费一级a毛片在线播 | 久久久久久综合一区中文字幕 | 日韩在线视频网址 | 99在线视频免费观看 | 台湾三级香港三级经典三在线 | 亚洲精品男人天堂 | 精品国产三级在线观看 | 成人午夜兔费观看网站 | 高清成人爽a毛片免费网站 高清大学生毛片一级 | 久操福利视频 | 亚洲 欧美 中文字幕 | 亚洲精品日韩中文字幕久久久 | 中文字幕一级毛片视频 | 亚洲国产99在线精品一区二区 |