阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用

409次阅读
没有评论

共计 1680 个字符,预计需要花费 5 分钟才能阅读完成。

1- 前言:

在 MySL 使用递归查询是很不方便的,不像 SQL Server 可以直接使用声明变量,使用虚拟表等等。如:DECLARE,BEGIN …  END   ,WHILE,IF 等等。

在 MySQL 可以通过创建函数,来使用上面的流程控制语句,Mysql 对函数的语法检查也是很苛刻的,可以说很烦人,不熟悉的人估计会哭。。。

2- 递归查询关键部分:

a- 我的表结构:

MySQL 递归查询_函数语法检查_GROUP_CONCAT 组合结果集的使用

 

b- 我的递归脚本:

用于查询:当前类目 ID 及所有的父级元素的 ID 使用逗号分割开的一个字符串:

下面脚本里使用了组合结果集的一个函数:GROUP_CONCAT,使用该函数可以在查不到结果的时候继续给 pid 赋值,从而跳出循环,详细可参考文章下面的注意点。

SELECT ParentID INTO pid FROM product_leimu WHERE 1=2; — 找不到数据的情况下,INTO 无法给 pid 赋值,pid 结果不变,

SELECT GROUP_CONCAT(ParentID) INTO pid FROM product_leimu WHERE 1=2; — 找不到数据的情况下,通过函数 GROUP_CONCAT 组合之后,可以继续使用 INTO 给 pid 赋值,pid 结果为 NULL

DROP FUNCTION IF EXISTS `fn_getLeimuPath`;

CREATE DEFINER = `sa`@`%` FUNCTION `fn_getLeimuPath`(`subId` int)
 RETURNS varchar(1000)
BEGINDECLARE pathID VARCHAR(4000) DEFAULT subId;
DECLARE pid INT default subid;

WHILE pid>0 DO
    SELECT GROUP_CONCAT(ParentID) INTO pid FROM product_leimu WHERE ID = pid;
    IF pid>0 THEN        SET pathID = concat(pid, ‘,’, pathID);
    END IF;
END WHILE;

RETURN pathID;
END;

查询结果展示:

MySQL 递归查询_函数语法检查_GROUP_CONCAT 组合结果集的使用

 

3- 一些需要注意的点,函数的一些特殊语法检查:

 a- 脚本结束标记检查:分号检查:

如:每个独立的脚本语句;流程控制语句结尾:END IF;END;END WHILE;

b- 流程控制语句组合:   

如:

IF 条件 THEN 

代码

ELSEIF

代码

       END IF;

 

WHILE 条件 DO

代码

END WHILE;

c- 特殊函数的使用:

函数:GROUP_CONCAT:将结果集链接在一起,使用逗号分隔,group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator‘分隔符’])

备注:这个函数可以在找不到数据的情况下,继续执行从而给 INTO 的变量赋值。比较神奇:

SELECT ParentID INTO pid FROM product_leimu WHERE 1=2;     -- 找不到数据的情况下,INTO 无法给 pid 的结果不变,
SELECT GROUP_CONCAT(ParentID) INTO pid FROM product_leimu WHERE 1=2;   -- 找不到数据的情况下,通过函数 GROUP_CONCAT 组合之后,可以继续使用 INTO 给 pid 赋值,NULL

我们这里是想在查不到的结果的时候,通过 WHILE 的判断结束循环, 如果不通过 GROUP_CONCAT 函数将结果传给 pid,那么将会进入无线循环当中 ,是很坑的!! 下面脚本的代码结果是:2

DECLARE pid INT;

SELECT ParentID INTO pid FROM product_leimu WHERE 1=2;

IF pid IS NULL THEN
    SET pid=1;
END IF;

SELECT GROUP_CONCAT(ParentID) INTO pid FROM product_leimu WHERE 1=2;

IF pid IS NULL THEN
    SET pid=2;
END IF;

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1680字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7800779
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...
Python自学26 – Cookie和Session

Python自学26 – Cookie和Session

Python 自学 26 – Cookie 和 Session 在学习 Web 开发时,Cooki...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛 NAS-7:手把手教你免费内网穿透 -Cloudflare tunnel 前言 大家好,我是星...
每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站 - 手机博物馆 -CHAZ 3D Experience 一句话介绍:一个用 3D 方式重温...
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...