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数据库无法被其他ip访问的解决方法

    mysql数据库无法被其他ip访问的解决方法

    这篇文章主要给大家介绍了关于mysql数据库无法被其他ip访问的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09
  • memcached的学习过程

    memcached的学习过程

    本篇文章是对笔者学习memcached的经历进行了介绍,需要的朋友参考下
    2013-06-06
  • MySQL修改数据的超详细教程

    MySQL修改数据的超详细教程

    在MySQL中可以使用 UPDATE 语句来修改、更新一个或多个表的数据,下面这篇文章主要给大家介绍了关于MySQL修改数据的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • MySQL中union和order by同时使用的实现方法

    MySQL中union和order by同时使用的实现方法

    下面小编就为大家带来一篇MySQL中union和order by同时使用的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • MySQL高并发生成唯一订单号的方法实现

    MySQL高并发生成唯一订单号的方法实现

    这篇文章主要介绍了MySQL高并发生成唯一订单号的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • MySQL百万级数据分页查询优化方案

    MySQL百万级数据分页查询优化方案

    在mysql中limit可以实现快速分页,但是如果数据到了几百万时我们的limit必须优化才能有效的合理的实现分页了,否则可能卡死你的服务器哦。
    2017-11-11
  • 简单了解MySQL SELECT执行顺序

    简单了解MySQL SELECT执行顺序

    MySQL数据据库中我们经常使用SQL SELECT语句来查询数据,那么关于它的执行顺序,下面小编来带大家简单了解一下
    2019-05-05
  • mysql unique option prefix myisam_recover instead of myisam-recover-options的解决方法

    mysql unique option prefix myisam_recover instead of myisam-

    Using unique option prefix myisam_recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead
    2016-05-05
  • 你需要理解的关于MySQL的锁知识

    你需要理解的关于MySQL的锁知识

    锁是MySQL里面最难理解的知识,但是又无处不在。一开始接触锁的时候,感觉被各种锁类型和名词弄得晕头转向,下面小编来简单介绍一下
    2019-05-05
  • mysql双向加密解密方式用法详解

    mysql双向加密解密方式用法详解

    这篇文章主要介绍了mysql双向加密解密方式用法,需要的朋友可以参考下
    2014-04-04

最新评论