Mysql根据某层部门ID查询所有下级多层子部门的示例

 更新时间:2020年12月30日 11:31:53   作者:Scoful  
这篇文章主要介绍了Mysql根据某层部门ID查询所有下级多层子部门的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

模拟表和数据脚本

复制以下sql语句生成一个叫sys_dept的表和插入若干构造好的有层级关系的数据,直接复制执行就ok

DROP TABLE IF EXISTS `sys_dept`;
CREATE TABLE `sys_dept` (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '部门编号',
 `p_id` int(11) DEFAULT NULL COMMENT '父级部门编号',
 `title` varchar(255) DEFAULT NULL COMMENT '父级部门名称',
 `is_open` int(11) DEFAULT NULL COMMENT '是否展开(0-展开,1-不展开)',
 `address` varchar(255) DEFAULT NULL COMMENT '部门地址',
 `create_time` datetime DEFAULT NULL COMMENT '创建时间',
 `remark` varchar(255) DEFAULT NULL COMMENT '备注',
 PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


INSERT INTO sys_dept (p_id,title,is_open,address,create_time,remark) VALUES 
(0,'总经办',1,'深圳','2019-04-10 14:06:32.000','大BOSS')
,(1,'销售部',0,'武汉','2019-04-10 14:06:32.000','程序员屌丝')
,(1,'运营部',0,'武汉','2019-04-10 14:06:32.000','无')
,(1,'生产部',0,'武汉','2019-04-10 14:06:32.000','无')
,(2,'销售一部',0,'武汉','2019-04-10 14:06:32.000','销售一部')
,(2,'销售二部',0,'武汉','2019-04-10 14:06:32.000','销售二部')
,(2,'销售三部',0,'广州','2019-04-10 14:06:32.000','销售三部')
,(2,'销售四部',0,'广州','2019-04-10 14:06:32.000','销售四部')
,(2,'销售五部',0,'广州','2019-04-10 14:06:32.000','销售五部')
,(3,'运营一部',0,'武汉','2019-04-10 14:06:32.000','运营一部')
,(3,'运营二部',0,'武汉','2019-04-10 14:06:32.000','运营二部')
,(3,'运营三部',0,'武汉','2019-04-10 14:06:32.000','运营三部')
,(3,'运营四部',0,'武汉','2019-04-10 14:06:32.000','运营四部')
,(3,'运营五部',0,'武汉','2019-04-10 14:06:32.000','运营五部')
,(4,'生产一部',1,'深圳','2019-11-23 09:50:23.000','生产一部')
,(4,'生产二部',1,'深圳','2019-11-23 09:50:23.000','生产二部')
,(4,'生产三部',1,'深圳','2019-11-23 09:50:23.000','生产三部')
,(5,'销售一部一组',1,'深圳','2019-11-23 09:50:23.000','销售一部一组')
,(5,'销售一部二组',1,'深圳','2019-11-23 09:50:23.000','销售一部二组')
,(5,'销售一部三组',1,'深圳','2019-11-23 09:50:23.000','销售一部三组')
,(6,'销售二部一组',1,'深圳','2019-11-23 09:50:23.000','销售二部一组')
,(6,'销售二部二组',1,'深圳','2019-11-23 09:50:23.000','销售二部二组')
,(17,'生产三部一组',1,'深圳','2019-11-23 09:50:23.000','生产三部一组')
,(17,'生产三部二组',1,'深圳','2019-11-23 09:50:23.000','生产三部二组')
,(17,'生产三部三组',1,'深圳','2019-11-23 09:50:23.000','生产三部三组')
;

根据部门ID查询所有子部门

select
 id,title
from
 (
 select
 t1.id,t1.title,
 if(find_in_set(p_id, @pids) > 0,
 @pids := concat(@pids, ',', id),
 0) as ischild
 from
 (
 select
  id,
  p_id,
  title
 from
  ssmdemo.sys_dept t
 order by
  p_id,
  id ) t1,
 (
  select @pids := 17) t2 ) t3
where
 ischild != 0

其中@pids := 17的17就是要查询的部门ID

到此这篇关于Mysql根据某层部门ID查询所有下级多层子部门的示例的文章就介绍到这了,更多相关Mysql ID查询所有下级多层子部门内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL 随机函数获取数据速度和效率分析

    MySQL 随机函数获取数据速度和效率分析

    最近做项目,需要做一个从mysql数据库中随机取几条数据出来。总所周知,order by rand 会死人的。。因为本人对大数据量方面的只是了解的很少,无解,去找百度老师。。搜索结果千篇一律。特发到这里来,供大家学习,需要的朋友可以参考下
    2016-11-11
  • MySQL 8.0 对 limit 的优化技巧

    MySQL 8.0 对 limit 的优化技巧

    从不同版本的 MySQL 发展轨迹来看 MySQL 的优化器越来越智能 (比如大家期待已久的直方图特性) ,能更多的减少人为干预,提升执行计划的准确性,这篇文章主要介绍了MySQL 8.0 对 limit 的优化,需要的朋友可以参考下
    2022-10-10
  • 使用Visual Studio Code连接MySql数据库并进行查询

    使用Visual Studio Code连接MySql数据库并进行查询

    这篇文章主要介绍了使用Visual Studio Code连接MySql数据库并进行查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • mysql中删除数据的四种方法小结

    mysql中删除数据的四种方法小结

    在MySQL数据库中,删除数据是一个常见的操作,它允许从表中移除不再需要的数据,本文就来介绍一下四种方法,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • MySQL关闭SSL的简单方法

    MySQL关闭SSL的简单方法

    这篇文章主要介绍了MySQL关闭SSL的简单方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Linux下安装MySQL教程

    Linux下安装MySQL教程

    上一篇文章详细介绍windows下MySQL安装教程,这篇就从最基本的安装MySQL-Linux环境开始,文章为绕MySQL安装展开内容,需要的朋友可以参考一下
    2021-11-11
  • macOS 下的 MySQL 8.0.17 安装与简易配置教程图解

    macOS 下的 MySQL 8.0.17 安装与简易配置教程图解

    这篇文章主要介绍了macOS 下的 MySQL 8.0.17 安装与简易配置教程,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • mysql创建用户授权步骤详解

    mysql创建用户授权步骤详解

    这篇文章主要介绍了mysql创建用户授权,本文分步骤给大家介绍的非常详细,对mysql创建用户授权详细步骤感兴趣的朋友一起看看吧
    2023-07-07
  • MySQL使用MD5加密算法进行数据加密功能

    MySQL使用MD5加密算法进行数据加密功能

    在现代的数据库应用中,数据的安全性和隐私性变得尤为重要,MySQL作为最流行的关系型数据库之一,提供了多种加密功能,允许用户对数据进行加密和解密操作,在这篇文章中,我们将深入探讨MySQL的加密功能,并重点介绍如何使用MD5加密算法进行加密,需要的朋友可以参考下
    2024-12-12
  • Mysql备份多个数据库代码实例

    Mysql备份多个数据库代码实例

    这篇文章主要介绍了Mysql备份多个数据库代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12

最新评论