mysql函数递归-与oracle中start with connect by prior递归作用相同

最近需要写一个文件夹递归操作,发现mysql中没有类似于oracle中的start with connect by prior语句递归,所以研究了一下,发现函数递归比较方便,这里记录一下

DROP FUNCTION IF EXISTS findDir;//如果存在则删除这个函数
CREATE FUNCTION findDir//5(areaId VARCHAR(255)//1)
RETURNS VARCHAR(4000)
BEGIN
DECLARE sTemp VARCHAR(4000);
DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';
SET sTempChd = CAST(areaId AS CHAR);

WHILE sTempChd IS NOT NULL DO
SET sTemp= CONCAT(sTemp,',',sTempChd);
SELECT GROUP_CONCAT(ID)//2 INTO sTempChd FROM mam_program_contents//3 WHERE FIND_IN_SET(PARENT_ID//4,sTempChd)>0;
END WHILE;
RETURN sTemp;
END;

1.这是输入参数的类型

2.这是表字段

3这是表名称

4这是表中父级字段

5这是你要定义的函数名

写好函数后,可直接使用sql语句进行查询

SELECT ID from mam_program_contents where FIND_IN_SET(ID,findDir("要查询的id"))

 

### 回答1: 您好!MySQL CONNECT BY 子句用于执行层次查询,常用于处理树形数据结构。其语法格式为: ``` SELECT ... FROM table_name [WHERE condition] START WITH expr1 CONNECT BY [PRIOR] expr2 = expr3 ``` 其,`table_name` 是要查询的表名,`condition` 是查询的过滤条件,`expr1` 是起始节点条件,`expr2` 是当前节点与父节点的关系,`expr3` 是当前节点与子节点的关系。 在 CONNECT BY 子句,`START WITH` 表示查询的起始节点条件,可以是任意的表达式。`CONNECT BY` 则用于定义当前节点与父节点、子节点之间的关系。如果使用 `PRIOR` 关键字,可以表示当前节点与父节点的关系,否则默认表示当前节点与子节点的关系。 以下是一个示例: ``` SELECT employee_name, manager_name, level FROM employees START WITH employee_name = 'Alice' CONNECT BY PRIOR employee_name = manager_name; ``` 该查询语句将从 `employees` 表查询出 Alice 的直接和间接下属,以及每个下属所处的层级。其,`START WITH employee_name = 'Alice'` 表示起始节点为 Alice,`CONNECT BY PRIOR employee_name = manager_name` 表示当前节点与父节点的关系为员工名等于上级经理名。 希望能对您有所帮助! ### 回答2: MySQL的`start with connect by`是一种在查询语句实现递归的方式。该语法基于标准的SQL-99的“WITH RECURSIVE”语法,但在MySQL使用稍有不同。 在MySQL,`start with`指定起始条件,`connect by`指定递归条件。它是通过指定一组与当前行关联的下一级行来实现递归的。 下面是一个示例,说明如何使用`start with connect by`语法: 假设我们有一个简单的表格`departments`,包含部门的名称(`name`)和父部门的ID(`parent_id`)。我们想要查询所有部门及其子部门的名称。我们可以使用以下查询: ``` WITH RECURSIVE department_hierarchy AS ( SELECT name, id, parent_id FROM departments WHERE parent_id IS NULL #起始条件 UNION ALL SELECT d.name, d.id, d.parent_id FROM departments d JOIN department_hierarchy dh ON d.parent_id = dh.id #递归条件 ) SELECT * FROM department_hierarchy; ``` 在上面的语句,`start with`条件是`parent_id IS NULL`,它选择顶层部门,也就是没有父部门的部门作为起始条件。`connect by`条件是`d.parent_id = dh.id`,它链接了当前部门(`d`)到它的父部门(`dh`),即通过`parent_id`和`id`来实现递归。 使用`start with connect by`语法可以轻松地查询嵌套结构的数据,比如组织结构、文件系统等等。在实现递归的过程,要注意避免死循环和过度递归,以免导致性能问题。 ### 回答3: MySQL的start with和connect by模块可以用于实现基于层次结构的查询,这种查询通常用于处理树形数据结构。start with关键字用于指定起始节点,而connect by子句用于指定两个列之间的关联关系。 start with子句用于在查询指定起始节点,其语法为: SELECT column1, column2, … FROM table_name START WITH condition; 其,condition是一个布尔表达式,用于筛选符合条件的起始节点。例如,查询员工表所有子部门为“Accounting”的员工的查询语句为: SELECT employee_name FROM employees START WITH department_name = 'Accounting' CONNECT BY PRIOR employee_id = manager_id; 上述查询,start with子句指定了起始节点为所有子部门为“Accounting”的员工,connect by子句指定了两个列之间的关联关系。PRIOR关键字用于指定当前行与上一行之间的父子关系,employee_id列是当前行的子部门,而manager_id列是上一行的部门负责人。 上述查询结果的输出为一个树形结构,其每个节点都是一位员工的名称,它的子节点是直接受其管理的员工。如果一个员工没有下属,则该节点下无子节点。在查询过程MySQL会逐个扫描树形结构,按照从顶层到底层的顺序进行遍历,将每个节点的信息输出到结果集。 在实际的应用,start with和connect by模块可以用于处理许多基于层次结构的业务场景,例如组织机构、产品分类、地理位置等。通过灵活运用这些模块,可以轻松实现树形查询,提高数据处理的效率和精度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值