SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。 本文主要和大家分享25行实现mysql树查询代码详解,希望能帮助到大家。需求:查找当前(任意)级别下的所有子节点。 通过自定义mysql函数实现,先贴代码,后面给出详细说明: delimiter $$
CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(1024)
BEGIN
DECLARE childListStr VARCHAR(1024);
DECLARE tempChildStr VARCHAR(1024);
DECLARE rootIdStr VARCHAR(64);
SET childListStr=NULL;
SET rootIdStr=cast(rootId as CHAR);
myloop: WHILE TRUE
DO
SELECT GROUP_CONCAT(id) INTO tempChildStr FROM test where FIND_IN_SET(parrent_id,rootIdStr)>0;
IF tempChildStr IS NOT NULL THEN
SET rootIdStr=tempChildStr;
IF childListStr IS NULL THEN
SET childListStr=tempChildStr;
ELSE
SET childListStr=concat(childListStr,',',tempChildStr);
END IF;
ELSE
LEAVE myloop;
END IF;
END WHILE;
RETURN childListStr;
END $$ 建表sql: CREATE TABLE `test` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`parrent_id` int(11) DEFAULT '0',
`name` varchar(32) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;
+------------+------------------+------+-----+---------+----------------+
|