如何根据子查询 所有父一级跟上跟上一级的所有节点?

select*fromuserInfowhereid=(selecttt2.parent_nofromuserInfott2whereid='1')现在是根据子ID查询出... select *
from userInfo
where id = (select tt2.parent_no from userInfo tt2 where id = '1')

现在是根据子ID查询出一级的父,怎么迭代的查询出所有 更上一级的..返回结果为当前ID和所有父辈,爷爷辈的数据
展开
 我来答
匿名用户
2012-12-12
展开全部
这个要看你的数据库, 是不是支持 CTE 了

SQL Server 2005 以上版本, 开始支持的。
DB2 也是支持的 (具体哪个版本开始就不清楚了)

with StepCTE AS
(
SELECT
*
FROM
userInfo
WHERE
id = '1'
UNION ALL
SELECT
tt2.*
FROM
userInfo tt2 JOIN StepCTE
ON ( tt2.id = StepCTE .parent_no )
)
SELECT
*
FROM
StepCTE

如果是 Oracle , 那么使用 lcglarry 的方法
追问
提交问题的时候刷新了下,百度有bug,所以我提交了两个一样的问题.. 你去回答另外一个吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友da38773
2012-12-12 · 超过29用户采纳过TA的回答
知道答主
回答量:70
采纳率:0%
帮助的人:71.9万
展开全部
SELECT u.id,u.parent_no
FROM userInfo u
CONNECT BY PRIOR u.parent_no=u.id
START WITH u.id='1'
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式