MYSQL GROUP_CONCAT() FIND_IN_SET()函数使用说明以及递归使用案例

目录

FIND_IN_SET(str,strlist),strlist以逗号分割

GROUP_CONCAT

递归


FIND_IN_SET(str,strlist),strlist以逗号分割

这样使用的话是查找str在strlist第一次出现的位置

select FIND_IN_SET(5,"k,8,5,7,5");

 

下面这样查tree表,查出strlist里有str的行

select * FROM tree where  FIND_IN_SET(5,pid);

 

GROUP_CONCAT

比如有以下数据,id相同的都是一组的成员,想把他们是一组的组合起来显示

想到是一组的肯定是用 select id,name FROM stu GROUP BY id 分组实现,但是这样只会显示同一组的第一个,而我们是要把同一组的都显示出来。

所以想要实现我们的需求就用GROUP_CONCAT(`name`)实现

select id,GROUP_CONCAT(`name`) FROM stu GROUP BY id;

 

递归

把这篇文章看不懂的说下 https://www.cnblogs.com/duanrantao/p/9359137.html

我们把数据改成简单的,再一步一步分析

SELECT
	GROUP_CONCAT( id ) INTO sTempChd 
FROM
	t_areainfo 
WHERE
	FIND_IN_SET( parentId, sTempChd )> 0;

上面循环里面的查询子节点可以分步看,第一次循环下面这样的,每个parentId都去看是不是有4,有的话就显示,然后在把显示的每行id合并起来

SELECT
	GROUP_CONCAT( id ) 
FROM
	t_areainfo 
WHERE
	FIND_IN_SET( parentId, '4' )> 0;

无GROUP_CONCAT( id )  

有GROUP_CONCAT( id ) 

第二次循环

SELECT
	GROUP_CONCAT( id ) 
FROM
	t_areainfo 
WHERE
	FIND_IN_SET( parentId, '5,6' )> 0;

所以SELECT queryChildrenAreaInfo(4);结果为$,4,5,6,65

最后查询所有子节点,上面这个方法已经把节点按照父子顺序显示出来了,所以只要显示这些结果(id)所在的数据就行

SELECT * FROM t_areainfo WHERE FIND_IN_SET(id,queryChildrenAreaInfo(4));

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值