如上:
这种方式是把对关联表的查询单独拎出来, association的属性有property:查询结果存放的属性,javaType:查询结果返回的类型,select:拎出来的查询语句,而column:相当于是把参数赋给查询语句。
我在宁外的地方看到别人把查询语句放在一起,查询结果单独处理的
链接:https://blog.csdn.net/qq_36544760/article/details/79502206
他这里是一个嵌套查询,相当于是对结果进行处理(其实把Role 的参数直接放进来也是可以的,这样做的好处就是不怕下次需要更多role里面的参数)
第二种:分步查询
就是分两个sql(这样写的话就需要维护两个sql跟对应的mapper了),在主mapper里面的子mapper(关联表)都有查询。
在主表里面用association关联到子表
主表:
字表
之所以能这样做的原因是:mybatis在mapperProxy里面生成mapper对应的sql时按照命名空间+sql的id形式作为相对应的key值。
补充一下另一种用collection标签的写法
这里unionId查出来是多条
对应collection里面是多条。