mysql5,创建临时表的方式,递归查询areaId以及所有的父级id的集合
时间: 2024-03-23 09:40:34 浏览: 72
SQL 递归查询,并将结果集保存在临时表中
5星 · 资源好评率100%
在 MySQL 5.x 中,我们可以使用以下方式创建临时表:
```
CREATE TEMPORARY TABLE temp_table (
id INT PRIMARY KEY,
name VARCHAR(255)
);
```
其中 `temp_table` 是临时表的名称,`id` 和 `name` 是表中的列名。
接下来,我们可以使用存储过程来实现递归查询 `areaId` 所有父级的 `id` 集合。假设我们有一个名为 `areas` 的表,其中包含 `id` 和 `parentId` 两个字段。我们可以使用以下存储过程来实现递归查询:
```
DELIMITER //
CREATE PROCEDURE recursive_query(IN areaId INT)
BEGIN
DECLARE done INT DEFAULT FALSE;
DECLARE temp_areaId INT;
DECLARE cur CURSOR FOR SELECT parentId FROM areas WHERE id = areaId;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
CREATE TEMPORARY TABLE temp_table (
id INT PRIMARY KEY
);
INSERT INTO temp_table VALUES (areaId);
OPEN cur;
read_loop: LOOP
FETCH cur INTO temp_areaId;
IF done THEN
LEAVE read_loop;
END IF;
INSERT INTO temp_table VALUES (temp_areaId);
CALL recursive_query(temp_areaId);
END LOOP;
CLOSE cur;
SELECT GROUP_CONCAT(id ORDER BY id ASC) AS parents FROM temp_table;
DROP TEMPORARY TABLE IF EXISTS temp_table;
END//
DELIMITER ;
```
存储过程接收一个 `areaId` 参数,表示需要查询的地区 ID。存储过程使用游标来查询指定 `areaId` 的父级 ID,然后将这些 ID 插入到临时表中。接着,存储过程递归调用自身,查询父级的父级 ID,直到查询到根节点为止。最后,存储过程使用 `GROUP_CONCAT` 函数将所有父级 ID 拼接成一个字符串返回。
可以使用以下命令来执行这个存储过程:
```
CALL recursive_query(10);
```
其中,10 是需要查询的地区 ID。
需要注意的是,这个存储过程只能查询单个地区的所有父级 ID,如果需要查询多个地区的所有父级 ID,可以使用循环来依次查询每个地区的父级 ID。另外,存储过程的执行效率可能会比较低,如果需要高效地查询大规模的数据,可以考虑使用其他数据库或者其他工具来进行递归查询。
阅读全文