mybatis子查询

 如上:

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

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

链接:https://blog.csdn.net/qq_36544760/article/details/79502206

mybatis子查询

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

 

第二种:分步查询

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

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

主表:

mybatis子查询

字表

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

 

相关文章: