mysql树目录查询语句优化提高查询效率

 更新时间:2024年10月11日 11:17:43   作者:guoqing2016  
在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql树目录查询语句优化提高查询效率的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在做mysql树目录查询的时候遇到了一个很奇妙的现象

我是先创建了一个树目录查询的函数叫 getDeptList()然后单独执行查询函数的效率很快

但当我放到sql语句里加个判断执行就会很慢了

累计查询出20条数据竟然要了0.5秒,那如果查出几百条不就1秒了 -_-||

后来想了一下可能是每次查询self_dept表的时候都会再执行一遍树目录的函数

然后就把sql语句改成了这样

可以看到,速度大幅度降低直接到了0.06

这里的优化思路是先计算好函数的结果,让函数只执行一遍,而不是根据self_dept表的判断进行多次计算

这里顺便记录一下mysql树目录排序的方法

sql:

select dept_id from (
    select t1.dept_id,
    if((find_in_set(parent_id, @pids) > 0 or find_in_set(dept_id, @pids) > 0), @pids := concat(@pids, ',', dept_id), 0) as ischild
    from (
        select dept_id,parent_id,dept_name from basis_sys_dept order by parent_id, dept_id
         ) t1,
			(select @pids := id) t2
		) t3 where ischild != 0

这个是可以直接写在sql语句内的,不过有个缺点:完全依靠排序,如果有子级在父级上面就会搜不到

sql:

delimiter // 
CREATE FUNCTION `getLst`(rootId INT) 
 RETURNS varchar(1000) 
 BEGIN 
   DECLARE sTemp VARCHAR(1000); 
  DECLARE sTempChd VARCHAR(1000); 
 
  SET sTemp = '$'; 
  SET sTempChd =cast(rootId as CHAR); 

  WHILE sTempChd is not null DO 
    SET sTemp = concat(sTemp,',',sTempChd); 
    SELECT group_concat(dept_id) INTO sTempChd FROM self_dept where FIND_IN_SET(parent_id,sTempChd)>0; 
  END WHILE; 
  RETURN sTemp; 
END 
//

这个是在mysql里创建一个函数,可以暂无发现什么bug(如有发现bug我会回来修改的)

(在复制使用的时候记得修改里面的表名和表字段 我的表:self_dept,id:dept_id,父级id:parent_id)

到此这篇关于mysql树目录查询语句优化的文章就介绍到这了,更多相关mysql树目录查询语句优化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中临时表的使用示例

    MySQL中临时表的使用示例

    这篇文章主要介绍了MySQL中的内存临时表的相关资料,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-11-11
  • mysql 5.7.27 winx64安装配置方法图文教程

    mysql 5.7.27 winx64安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 5.7.27 winx64安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • Linux系统下实现远程连接MySQL数据库的方法教程

    Linux系统下实现远程连接MySQL数据库的方法教程

    MySQL默认root用户只能本地访问,不能远程连接管理mysql数据库,Linux如何开启mysql远程连接?下面这篇文章主要给大家介绍了在Linux系统下实现远程连接MySQL数据库的方法教程,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-06-06
  • MySQL 创建主键,外键和复合主键的语句

    MySQL 创建主键,外键和复合主键的语句

    MySQL 创建主键,外键和复合主键的方法,需要的朋友可以参考下。
    2009-12-12
  • MySQL5.7完全卸载步骤详解

    MySQL5.7完全卸载步骤详解

    这篇文章主要介绍了MySQL5.7完全卸载的详细步骤以及把中间遇到的问题做了分析,需要的朋友跟着操作下吧。
    2018-02-02
  • MySQL字符串函数详解(推荐)

    MySQL字符串函数详解(推荐)

    下面小编就为大家带来一篇MySQL字符串函数详解(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • MySQL中union和unionall区别

    MySQL中union和unionall区别

    本文主要介绍了MySQL中union和unionall区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • MySQL可直接使用的查询表的列信息(实现方案)

    MySQL可直接使用的查询表的列信息(实现方案)

    本文介绍了如何使用SQL快速将下划线命名的表字段转换为驼峰命名格式,包括确定下划线位置、找到第一个字符、截取并拼接字符串等步骤,通过使用LOCATE、CONCAT、UCASE和LOWER等函数,可以实现高效的字段命名转换,感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • Mysql中新建用户及授权的方法分享

    Mysql中新建用户及授权的方法分享

    这篇文章给大家汇总介绍了Mysql中新建用户及授权的方法,首先介绍的是作者自己的项目经历,后面附上了参考文章,希望能对大家学习mysql有所帮助。
    2016-07-07
  • 一些mysql启动参数的说明和优化方法

    一些mysql启动参数的说明和优化方法

    要求MySQL能有的连接数量。当主要MySQL线程在一个很短时间内得到非常多的连接请求,这就起作用,然后主线程花些时间(尽管很短)检查连接并且启动一个新线程。
    2011-04-04

最新评论