>백엔드 개발 >PHP 튜토리얼 >求一个sql语句(有点难,求高手)

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

WBOY
WBOY원래의
2016-06-23 14:23:05926검색

本帖最后由 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

学习了,不错。

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

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.