让MySQL中单句实现无限层次父子关系查询的方法

本文讲解"让MySQL中单句实现无限层次父子关系查询的方法",用于解决相关问题。

在 SQL Server 中,使用 CTE 表达式很容易做到无限层次父子关系查询;在不支持CTE表达式的版本中,借助函数递归也可以轻松实现。
在 MySQL 中,这个需求的实例稍显复杂, MySQL 中没有支持递归的查询,没有表值函数,函数不支持递归,所以通常都是用循环实现,显得比较别扭。今天看到一个用单条语句实现的递归查询,想法独特,分享一下。

相关mysql视频教程

表结构和数据

CREATE TABLE table1(id int, name varchar(10), parent_id int); 
INSERT table1 VALUES 
(1, ‘Home’,        0), 
(2, ‘About’,       1), 
(3, ‘Contact’,     1), 
(4, ‘Legal’,         2), 
(5, ‘Privacy’,      4), 
(6, ‘Products’,   1), 
(7, ‘Support’,     2);

查询 id = 5 的所有父级

SELECT ID.level, DATA.* FROM( 

  SELECT 

      @id as _id, 

      (   SELECT @id := parent_id 

          FROM table1 

          WHERE id = @id 

      ) as _pid, 

      @l := @l+1 as level 

  FROM table1, 

      (SELECT @id := 5, @l := 0 ) b 

  WHERE @id > 0 
) ID, table1 DATA 
WHERE ID._id = DATA.id 
ORDER BY level;

根据这个父级查询方法,很容易可以写出查所有子级的,下面的查询 id=2 的所有子级

SELECT ID.level, DATA.* FROM( 

  SELECT 

      @ids as _ids, 

      (   SELECT @ids := GROUP_CONCAT(id) 

          FROM table1 

          WHERE FIND_IN_SET(parent_id, @ids) 

      ) as cids, 

      @l := @l+1 as level 

  FROM table1, 

      (SELECT @ids :=’1’, @l := 0 ) b 

  WHERE @ids IS NOT NULL 
) id, table1 DATA 
WHERE FIND_IN_SET(DATA.id, ID._ids) 
ORDER BY level, id

关于 "让MySQL中单句实现无限层次父子关系查询的方法" 就介绍到此。希望多多支持编程宝库

本文讲解"mysql中更新锁与排它锁的示例分析",用于解决相关问题。一直没有认真了解UPDATE操作的锁,最近在MSDN论坛上看到一个问题,询问堆表更新的死锁问题,问题很简单,有类似这样的表及数据:CR ...