Mysql查询语句如何实现无限层次父子关系查询
一、前言
单表存储上下级关系,使用mysql 内置函数循环递归查出来
二、相关语法函数介绍
@
@是用户变量,@@是系统变量。
:=
不只在set和update时时赋值的作用,在select也是赋值的作用。
group_concat()
将group by产生的同一个分组中的值连接起来,返回一个字符串结果。
FIND_IN_SET()
查询字段(strlist)中包含(str)的结果,返回结果为null或记录
三、具体实现
创建表
查询父级为 2 的下级 无限级查询
SELECT @ids AS _ids, ( SELECT @ids := GROUP_CONCAT( descendant ) FROM relation WHERE FIND_IN_SET( ancestor, @ids ) ) AS cids, @l := @l + 1 AS LEVEL FROM relation, ( SELECT @ids := 2, @l := 0 ) b WHERE @ids IS NOT NULL

列表化
SELECT descendant.LEVEL, DATA.* FROM ( SELECT @ids AS _ids, ( SELECT @ids := GROUP_CONCAT( descendant ) FROM relation WHERE FIND_IN_SET( ancestor, @ids ) ) AS cids, @l := @l + 1 AS LEVEL FROM relation, ( SELECT @ids := 2, @l := 0 ) b WHERE @ids IS NOT NULL ) descendant, sys_dept_relation DATA WHERE FIND_IN_SET( DATA.descendant, descendant._ids ) ORDER BY LEVEL, DATA.descendant

查询ID为 8 的上级 无限级查询
SELECT @id AS _id, ( SELECT @id := ancestor FROM relation WHERE descendant = @id ) AS _pid, @l := @l + 1 AS LEVEL FROM relation, ( SELECT @id := 8, @l := 0 ) b WHERE @id > 0

四、效率问题
我目前测试表有8千多数据量


EXPLAN 相关参数
Select_type:
PRIMARY:查询中最外层的SELECT(如两表做UNION或者存在子查询的外层的表操作为PRIMARY,内层的操作为UNION)DERIVED:被驱动的SELECT子查询(子查询位于FROM子句)UNCACHEABLE SUBQUERY:一个子查询的结果不能被缓存,必须重新评估外链接的第一行
Type:
NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引,例如从一个索引列里选取最小值可以通过单独索引查找完成。index: Full Index Scan,index与ALL区别为index类型只遍历索引树System:system是const类型的特例,当查询的表只有一行的情况下,使用system
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
MySQL配置文件my.cnf中文详解附mysql性能优化方法分享
Mysql参数优化对于新手来讲,是比较难懂的东西,其实这个参数优化,是个很复杂的东西,对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的观察以及调试,才有可能得到最佳效果。2011-09-09
CentOS6.7 mysql5.6.33修改数据文件位置的方法
mysql存放的数据文件,分区容量较小,目前已经满,导致mysql连接不上,怎么解决呢?下面小编给大家分享CentOS6.7 mysql5.6.33修改数据文件位置的方法,一起看看吧2017-06-06
安装和使用percona-toolkit来辅助操作MySQL的基本教程
这篇文章主要介绍了安装和使用percona-toolkit来辅助操作MySQL的基本教程,这里举了五个最常见的命令用法,需要的朋友可以参考下2015-11-11
MySQL4 File ‘c:\mysql\share\charsets\?.conf’ not found (Errc
File ‘c:\mysql\share\charsets\?.conf’ not found (Errcode: 22) Character set ‘#33′ is not a compiled character set and is not specified in the ‘c:\mysql\share\charsets\Index’ file2013-08-08
MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解
`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期时间格式组合,感兴趣的朋友一起看看吧2025-03-03
如何查本地mysql的username和密码及更新密码几种方式
这篇文章主要介绍了光宇如何查找本地MySQL数据库的用户名和密码,包括查看当前用户、列出所有用户、重置密码以及检查配置文件,文中通过代码介绍的非常详细,需要的朋友可以参考下2024-11-11


最新评论