MySQL8.0和MySQL5.7的迭代查询

本文介绍如何在MySQL8.0和MySQL5.7中实现上级和下级数据的迭代查询,包括递归查询所有上级及下级节点的方法,并展示了如何构建全路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL5.7是不支持 WITH AS 子句的,只有MySQL 8.0 以上版本才支持。

查询上级

MySQL8.0迭代查询所有上级(包含本身)

	with recursive region_temp as (
    select *  from base_region_info  where region_id = '110101001'
    union all
    select t.*
    from base_region_info t
             inner join region_temp region_temp2 on t.region_id = region_temp2.parent_id
						 where t.region_id <> 0
)
select * from region_temp;

包含全路径

	with recursive region_temp as (
    select *,region_name all_path  from base_region_info   where region_id = '110101001'
    union all
    select t.*,concat(region_temp2.all_path,'>',t.region_name) all_path 
    from base_region_info t
             inner join region_temp region_temp2 on t.region_id = region_temp2.parent_id
						 where t.region_id <> 0
)
select * from region_temp;

MySQL5.7迭代查询所有上级(包含本身)

SELECT t2.*
FROM ( 
    SELECT  @id as _id, 
        (SELECT @id := parent_id FROM base_region_info WHERE region_id = _id) p
    FROM 
        (SELECT @id := "110101001") v, 
        base_region_info 
    WHERE @id <> "0"
		) t1 
JOIN base_region_info t2 ON t1._id = t2.region_id;

查询下级

MySQL8.0迭代查询所有下级(包含本身)

	with recursive region_temp as (
    select *  from base_region_info  where region_id = '110101001'
    union all
    select t.* from base_region_info t
                        inner join region_temp region_temp2 on t.parent_id = region_temp2.region_id
)
select
    *
from region_temp

包含全路径

	
	with recursive region_temp as (
    select *,region_name all_path  from base_region_info  where region_id = '110101001'
    union all
    select t.*,concat(region_temp2.all_path,'>',t.region_name) all_path 
		 from base_region_info t
                        inner join region_temp region_temp2 on t.parent_id = region_temp2.region_id
)
select
    *
from region_temp

MySQL5.7迭代查询所有下级(包含本身)

SELECT T2.*
FROM
	(
	SELECT
		@ids AS _ids,
		(SELECT @ids := GROUP_CONCAT(region_id) FROM base_region_info WHERE FIND_IN_SET(parent_id,@ids)) AS cids 
	FROM
		base_region_info ,
		( SELECT @ids := '110101001' ) b 
	WHERE
		@ids <> '0' 
	) T1 ,
	base_region_info T2
WHERE
	FIND_IN_SET(T2.region_id,T1 ._ids )
数据库迭代查询作业 emp(eno, ename, salary, mgr),其中mgr是员工领导,设计约束:要求领导的工资不能低于他的下属平均工资。(注意,这是一个递归查询) 下面是一些样例数据 CREATE TABLE dbo.Employees ( empid INT NOT NULL PRIMARY KEY, mgrid INT NULL REFERENCES dbo.Employees, empname VARCHAR(25) NOT NULL, salary MONEY NOT NULL, CHECK (empid mgrid) ); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(1, NULL, 'David', $10000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(2, 1, 'Eitan', $7000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(3, 1, 'Ina', $7500.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(4, 2, 'Seraph', $5000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(5, 2, 'Jiru', $5500.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(6, 2, 'Steve', $4500.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(7, 3, 'Aaron', $5000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(8, 5, 'Lilach', $3500.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(9, 7, 'Rita', $3000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(10, 5, 'Sean', $3000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(11, 7, 'Gabriel', $3000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(12, 9, 'Emilia' , $2000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(13, 9, 'Michael', $2000.00); INSERT INTO dbo.Employees(empid, mgrid, empname, salary) VALUES(14, 9, 'Didi', $1500.00);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值