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 表关联查询内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. MySQL中InnoDB和MyISAM类型的差别2. 如何查看SQL SERVER的版本3. ORACLE常用傻瓜問題1000問(之十二)4. Sql Server 2000数据库日志日益庞大的解决方法5. Mybatis 实现一个搜索框对多个字段进行模糊查询6. SQL Server 2005 FOR XML嵌套查询使用详解7. 在Redhat Enterprise server 3上安装oracle9iR2的注意事项8. 引入mybatis-plus报 Invalid bound statement错误问题的解决方法9. MySQL InnoDB行记录存储结构分析10. MySQL 常用函数总结