MySQL下实现纯SQL语句的递归查询

需求

有一个部门表,部门表中有一个字段用于定义它的父部门;

在实际业务中有一个『部门中心』的业务;

比如采购单,我们需要显示本部门及子部门的采购单显示出来。

结构

数据如下:

实现方式如下:

WITH RECURSIVE recursion (id, name, parent_id,sys_user_id) AS(SELECT T1.id, T1.name,   T1.parent_id  ,t1.sys_user_idfrom sys_dept T1where T1.id=360 -- 要查询的IDUNION ALLSELECT T2.id, T2.name, T2.parent_id,T2.sys_user_idfrom sys_dept T2, recursion T3WHERE T2.parent_id=T3.id)SELECT T.id, T.name,  T.parent_id,T.sys_user_idFROM recursion T;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/724270.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

内衣洗衣机名牌排行榜前十名:十款强大性能内衣洗衣机精心力荐

小型内衣洗衣机一般是为婴儿宝宝,或者一些有特殊需要的用户而设计使用的,宝宝衣物换洗频繁,而且对卫生方面的除菌要求高,而为避免交叉感染,所以一般不适合和大人的衣物放在一起洗,因此对于有宝宝的家庭来说…

Android多线程实现方式及并发与同步,Android面试题汇总

一. 开发背景 想要成为一名优秀的Android开发,你需要一份完备的知识体系,在这里,让我们一起成长为自己所想的那样。 我们的项目需要开发一款智能硬件。它由 Web 后台发送指令到一款桌面端应用程序,再由桌面程序来控制不同的硬件设…

Plasmo框架开发浏览器插件配置newtab页面,并可以跳转

有关plasmo框架添加页面可以看官方文档:Browser Extension Pages – Plasmo 想要给插件添加一个页面,可以通过添加newtab.tsx添加: 或者通过添加tabs文件夹添加多个页面: 想要访问的话,只需要通过:chrome-…

Python爬虫实战第三例【三】【上】

零.实现目标 爬取视频网站视频 视频网站你们随意,在这里我选择飞某速(狗头保命)。 例如,作者上半年看过的“铃芽之旅”,突然想看了,但是在正版网站看要VIP,在盗版网站看又太卡了,…

2024年腾讯云轻量16核32G28M服务器优惠价格3468元15个月

2024年腾讯云轻量16核32G28M服务器优惠价格3468元15个月,380GB SSD云硬盘,6000GB月流量。 一张表看懂腾讯云服务器租用优惠价格表,一目了然,腾讯云服务器分为轻量应用服务器和云服务器CVM,CPU内存配置从2核2G、2核4G、…

[力扣100] 55.跳跃游戏

添加链接描述 思路: 只要能跳到下标为x的位置,那么x之前的位置就都可以跳到只要能跳到的最大位置大于数组长度-1,那么就说明可以跳到最后一个位置rightmost来记录能跳到的最大下标;当这个值大于长度-1时就可以返回True了 class …

页面路由跳转

路由方法 routTeam(row, column, cell, event) { console.log(row) console.log("111") const teamId 123 this.$router.push(/routTeam/team/ row.teamId) }, // 公共路由 export const constantRoutes [ { path: /routTeam, component: Layout, hidden: true…

Linux下du命令和df命令的使用

du命令作用是估计文件系统的磁盘已使用量,常用于查看文件或目录所占磁盘容量。df命令是统计磁盘使用情况,可以用来查看磁盘已被使用多少空间和还剩余多少空间。du命令语法du [选项] [文件或目录名称]参数:-a:--all, 列…

C#,数值计算,求解微分方程的预测校正法(修正欧拉法)算法与源代码

Leonhard Euler 1 微分方程 微分方程,是指含有未知函数及其导数的关系式。解微分方程就是找出未知函数。 微分方程是伴随着微积分学一起发展起来的。微积分学的奠基人Newton和Leibniz的著作中都处理过与微分方程有关的问题。微分方程的应用十分广泛,可…

To 有缘看到的朋友,To myself

To 有缘看到的朋友,To myself 零、00时光宝盒 我们生而为人,而不是什么神仙妖怪,自然逃不脱凡尘种种不易。 世界并不完美,面对很多事情我们都很无奈甚至悲哀,但生活总要继续下去,当困难悄悄地来临&#xff…

【vue3之组合式API】

组合式API 一、setup1.写法2.如何访问3.语法糖4.同步返回对象 二、reactive()和ref()1.reactive()2.ref() 三、computed四、watch函数1侦听单个数据2.侦听多个数据3. immediate4. deep5.精确侦听对象的某个属性 五、生命周期函数六、组件通信1.父传子2. 子传父 七、模版引用1. …

shell脚本一键部署docker

Docker介绍 Docker 是一个开源的平台,用于开发、交付和运行应用程序。它利用容器化技术,可以帮助开发人员更轻松地打包应用程序及其依赖项,并将其部署到任何环境中,无论是开发工作站、数据中心还是云中。以下是 Docker 的一些关键…

declare module ‘global‘

在 TypeScript 中,declare module global 是一个特殊的模块声明,用于扩展全局作用域中的对象或接口。这通常用于为浏览器环境中的全局对象(如 window)或 Node.js 环境中的全局对象(如 global)添加类型声明。…

vue模拟数据mock放哪

在Vue中进行模拟数据的mock可以放在多个地方,具体取决于需求和个人偏好。以下是几种常见的方式: 在组件内部:可以在Vue组件的methods中编写模拟数据的逻辑。这种方式适用于只在当前组件中需要使用模拟数据的情况。 使用Mock.js库&#xff1a…

【Linux】软件包管理器yum

目录 一、yum是什么? 二、查看软件包 三、安装与卸载软件 1、如何安装软件 2、如何卸载软件 四、yum源的配置 一、yum是什么? 在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序. 但是这样太麻烦了, 于是有些人…

Webserve(4): HTTP解析

// 写HTTP响应 bool http_conn::write() {int temp 0;if ( bytes_to_send 0 ) {// 将要发送的字节为0&#xff0c;这一次响应结束。modfd( m_epollfd, m_sockfd, EPOLLIN ); init();return true;}while(1) {// 分散写temp writev(m_sockfd, m_iv, m_iv_count);if ( temp <…

如何在华为云服务器部署安防监控EasyCVR平台?

随着视频技术的快速发展&#xff0c;安防视频汇聚平台EasyCVR可支持的协议也在不断拓展&#xff0c;平台兼容多类型的协议接入&#xff0c;包括&#xff1a;国标GB28181、RTSP/Onvif、RTMP&#xff0c;以及厂家的私有协议与SDK&#xff0c;如&#xff1a;海康ehome、海康sdk、大…

YOLOv7创新改进:SPPF创新涨点篇 | SPPELAN:SPP创新结合ELAN ,效果优于SPP、SPPF| YOLOv9

💡💡💡本文独家改进:新颖SPPF创新涨点改进,SPP创新结合ELAN,来自于YOLOv9,助力YOLOv7,将SPPELAN代替原始的SPPF 💡💡💡在多个私有数据集和公开数据集VisDrone2019、PASCAL VOC实现涨点 收录 YOLOv7原创自研 https://blog.csdn.net/m0_63774211/category…

C语言常见关键字:一文打尽

关键字 1. 前言2. 什么是关键字3. extern-声明外部符号4. auto-自动5. typedef-类型重定义&#xff08;类型重命名&#xff09;6. register-寄存器6.1 存储器6.2 register关键字的作用 7. static-静态7.1 static修饰局部变量7.1.1 代码对比7.1.2 原理分析 7.2 static修饰全局变…

Java中常见延时队列的实现方案总结

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…