兄弟们,请教个sql语句

有这么一个posts表

id name parent_id
1 公告 0
2 更新说明 1
3 帮助中心 0

然后我要根据父亲name,查询出父亲本身以及其下一级的id。比如我想查公告和公告下一级的id,在上面例子来说,也就是根据name=公告的已知条件,查出id=1和id=2这两条记录,有什么效率高点的sql写法吗。

我目前想到的写法是这样的,但是我感觉这样效率好像太低了
select * from posts where parend_id = (select id from posts where name='公告' ) union (select * from posts where name='公告' )

讨论数量: 5

我猜测该表数据不大,如果是这样的话,建议你通过程序去实现分类树的构建和查找功能。把数据全部查出来就好,程序封装好查找的方法

1个月前 评论

select * from (select * from posts where name ='公告') as t1 union (select * from posts where parent_id = t1.id)

1个月前 评论

这个很常见,我的做法是:把有效的数据全部查出来,然后在程序里面去做递归,形成树。这也是很常见的做法。希望有帮助。

一般会结合层级字段,这样可以无限层级。

4周前 评论

select *,IFNULL((select id from posts where parent_id=a.id),0) as child_id from posts as a where name = '公告'

不过我也建议你用递归的方式做成树状图

2周前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!