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
栏 目:其它数据库
下一篇:navicat 连接数据库隔段时间后自动断开连接的解决方案
本文标题:Mysql根据某层部门ID查询所有下级多层子部门的示例
本文地址:https://zz.feitang.co/shujuku/34727.html
您可能感兴趣的文章
- 12-31hiredis从安装到项目实战操作
- 12-31phpmyadmin登录时怎么指定服务器ip和端口
- 12-31MySQL线上死锁分析实战
- 12-31MySQL 触发器的使用和理解
- 12-31MySQL 字段默认值该如何设置
- 12-31Redis主从同步配置的方法步骤(图文)
- 12-31MySQL 字符串拆分操作(含分隔符的字符串截取)
- 12-31redis 交集、并集、差集的具体使用
- 12-31MySQL精讲之二:DML数据操作语句
- 12-31PostgreSQL判断字符串是否包含目标字符串的多种方法


阅读排行
推荐教程
- 12-23PL/SQL登录Oracle数据库报错ORA-12154:TNS:无法解析指定的连接标识符
- 12-23使用imp和exp命令对Oracle数据库进行导入导出操作详解
- 12-11mysql代码执行结构实例分析【顺序、分支、循环结构】
- 12-08添加mysql的用户名和密码是什么语句?
- 12-05mysql的事务,隔离级别和锁用法实例分析
- 12-23详解Oracle游标的简易用法
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程





