MyBatis实现两种查询树形数据的方法详解(嵌套结果集和递归查询)
目录
- 方法一:使用嵌套结果集实现
- 1,准备工作
- 2,实现代码
- 方法二:使用递归查询实现
方法一:使用嵌套结果集实现
1,准备工作
(1)假设我们有如下一张菜单表 menu,其中子菜单通过 parendId 与父菜单的 id 进行关联:
文章图片
(2)对应的实体类如下:
@Setter@Getterpublic class Menu {private Integer id; private String name; private List
2,实现代码
(1)假设目前菜单只有两级,MyBatis 语句如下。其原理是通过关联查询,一次性将数据查询出来,然后根据 resultMap 的配置进行转换,构建目标实体类。
优点:只由于该方法需要访问一次数据库就可以了,不会造成严重的数据库访问消耗。
selectm1.id as id,m1.name as name,m2.id as id2,m2.name as name2from menu m1,menu m2where m1.`id`=m2.`parentId`
最终获取到的结果如下:
文章图片
(2)如果菜单有三级的话,则 MyBatis 语句做如下修改,再增加一个嵌套结果级即可:
selectm1.id as id,m1.name as name,m2.id as id2,m2.name as name2,m3.id as id3,m3.name as name3from menu m1,menu m2,menu m3where m1.`id`=m2.`parentId` and m2.`id`=m3.`parentId`
文章图片
(3)如果菜单级别不确定,可能只有一级、或者有两级、或者有三级(最多三级),可以对 SQL 语句稍作修改,改成左连接即可:
selectm1.id as id,m1.name as name,m2.id as id2,m2.name as name2,m3.id as id3,m3.name as name3from menu m1left join menu m2 on m1.id=m2.parentIdleft join menu m3 on m2.id=m3.parentIdwhere m1.parentId=0
文章图片
方法二:使用递归查询实现 (1)下面代码使用递归查询出所有菜单(无论层级有多深):
递归查询好处在于简单易懂,通过简单的配置就可以达到目标效果。不足之处在于由于需要多次查询数据库,如果结果集记录条数过大,会造成较大的数据库访问消耗。
select * from menu where parentId = 0 select * from menu where parentId = #{id}
文章图片
(2)关联查询还可以传递多个参数,此时传递部分 column 的值为多个键值对(由于这里传递的 name 其实没有用到,只是做个演示,下面的查询结果同前面的是一样的):
select * from menu where parentId = 0 select * from menu where parentId = #{id}
【MyBatis实现两种查询树形数据的方法详解(嵌套结果集和递归查询)】到此这篇关于MyBatis实现两种查询树形数据的方法详解(嵌套结果集和递归查询)的文章就介绍到这了,更多相关MyBatis 查询树形数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- mybatisplus如何在xml的连表查询中使用queryWrapper
- mybatisplus|mybatisplus where QueryWrapper加括号嵌套查询方式
- MybatisPlus|MybatisPlus LambdaQueryWrapper使用int默认值的坑及解决
- MybatisPlus使用queryWrapper如何实现复杂查询
- python学习之|python学习之 实现QQ自动发送消息
- 孩子不是实现父母欲望的工具——林哈夫
- opencv|opencv C++模板匹配的简单实现
- Node.js中readline模块实现终端输入
- java中如何实现重建二叉树