mybatis子查询

博客介绍了MyBatis关联表查询的方式。一种是将关联表查询单独拎出,介绍了association属性;还提到有人将查询语句放一起、单独处理结果。另一种是分步查询,分两个sql,主表用association关联子表,还补充了collection标签写法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 如上:

这种方式是把对关联表的查询单独拎出来, association的属性有property:查询结果存放的属性,javaType:查询结果返回的类型,select:拎出来的查询语句,而column:相当于是把参数赋给查询语句。

我在宁外的地方看到别人把查询语句放在一起,查询结果单独处理的

链接:https://blog.youkuaiyun.com/qq_36544760/article/details/79502206

他这里是一个嵌套查询,相当于是对结果进行处理(其实把Role 的参数直接放进来也是可以的,这样做的好处就是不怕下次需要更多role里面的参数)

 

第二种:分步查询

就是分两个sql(这样写的话就需要维护两个sql跟对应的mapper了),在主mapper里面的子mapper(关联表)都有查询。

在主表里面用association关联到子表

主表:

字表

 之所以能这样做的原因是:mybatis在mapperProxy里面生成mapper对应的sql时按照命名空间+sql的id形式作为相对应的key值。

补充一下另一种用collection标签的写法

这里unionId查出来是多条

 对应collection里面是多条。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值