如何根据子查询 所有父一级跟上跟上一级的所有节点?
select*fromuserInfowhereid=(selecttt2.parent_nofromuserInfott2whereid='1')现在是根据子ID查询出...
select *
from userInfo
where id = (select tt2.parent_no from userInfo tt2 where id = '1')
现在是根据子ID查询出一级的父,怎么迭代的查询出所有 更上一级的..返回结果为当前ID和所有父辈,爷爷辈的数据 展开
from userInfo
where id = (select tt2.parent_no from userInfo tt2 where id = '1')
现在是根据子ID查询出一级的父,怎么迭代的查询出所有 更上一级的..返回结果为当前ID和所有父辈,爷爷辈的数据 展开
2个回答
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 的方法
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,所以我提交了两个一样的问题.. 你去回答另外一个吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
SELECT u.id,u.parent_no
FROM userInfo u
CONNECT BY PRIOR u.parent_no=u.id
START WITH u.id='1'
FROM userInfo u
CONNECT BY PRIOR u.parent_no=u.id
START WITH u.id='1'
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询