SELECT
@r AS _id,
(SELECT @r := parent_id FROM t_category WHERE id = _id) AS parent_id,
@l := @l + 1 AS lvl
FROM (SELECT @r := 89, @l := 0) vars, t_category t
WHERE @r <> 0 AND parent_id >0;
如果 @r = 89 在库中是存在的,这时候结果正常 如果 @r = 89 在库中是不存在的,就会出现以下记录
_id parent_id lvl
89 NULL 1
89 NULL 2
...
再添加 and parent_id is not null 也一样输出上面的纪录。 但是如果在外面再包上一层 再判断 parent_id is not null 结果就正常了。 请教一下各位大佬这是什么问题?
还有像这种查询所有父 /子节点的需求最佳方案一般是在代码层解决,还是像这样在 sql 层解决?还有没有更好的方案?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.