欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

求一个sql语句(有点难,求高手)

程序员文章站 2022-05-19 22:30:29
...
本帖最后由 dz215136304 于 2013-07-28 11:58:31 编辑 表
id pid title
1 0 标题1
2 0 标题2
3 2 标题3
4 2 标题4
5 2 标题5
6 5 标题6

需求 将表里的数据都查出来 并且如果pid等于别的数据id的话 id那条数据自动生成个字段,字段的数据是pid连接起来的且通过,分割 ,效果如下

id pid title pidss
1 0 标题1
2 0 标题2 3,4,5
3 2 标题3
4 2 标题4
5 2 标题5 6
6 5 标题6

回复讨论(解决方案)

这没有什么复杂的

select a.*, pidss from tbl_name a left join  (select *, group_concat(id) as pidss from tbl_name where pid>0 group by pid) t on a.id=t.pid

不过当层次深的时候就不一定是你期望的了

过来看一看。

二楼的正确,用做链接保证不丢失数据,用group_cancat函数将单值属性连接起来编程多值属性。

group_cancat函数可以解决

group_concat

学习了,不错。

学习了,不错,本来我对这个还不太了解呢,这次了解了

学习了,不错学习了,不错