Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
所有祖先/父代和子代的单层次查询(DB2/SQLServer)_Sql_Sql Server_Db2_Hierarchical - Fatal编程技术网

所有祖先/父代和子代的单层次查询(DB2/SQLServer)

所有祖先/父代和子代的单层次查询(DB2/SQLServer),sql,sql-server,db2,hierarchical,Sql,Sql Server,Db2,Hierarchical,我找到了Oracle的解决方案,在两个分层连接查询上使用UNION ALL,一个获取祖先,另一个获取子查询。 我希望对DB2和sqlserver实现同样的效果 我知道一个元素,它可以是层次结构中的根、分支或叶。我需要获取它的整个层次结构 假设我有itemid='item3'和class='myclass',我需要找到它的祖先和孩子,我想到了: with ancestor (class, itemid, parent, base, depth) as ( select root.class


我找到了Oracle的解决方案,在两个分层连接查询上使用UNION ALL,一个获取祖先,另一个获取子查询。
我希望对DB2sqlserver实现同样的效果
我知道一个元素,它可以是层次结构中的根、分支或叶。我需要获取它的整个层次结构

假设我有itemid='item3'和class='myclass',我需要找到它的祖先和孩子,我想到了:

with ancestor (class, itemid, parent, base, depth)
as (
    select root.class, root.itemid, root.parent, root.itemid, 0
    from item root
    where root.class = 'myclass'
    and root.itemid = 'item3'
--      union all
--  select child.class, child.itemid, child.parent, root.base, root.depth+1
--  from ancestor root, item child
--  where child.class = root.class
--  and child.parent = root.itemid
        union all
    select parent.class, parent.itemid, parent.parent, parent.itemid, root.depth-1
    from ancestor root, item parent
    where parent.class = root.class
    and parent.itemid = root.parent
)
select distinct class, itemid, parent, base, depth
from ancestor 
order by class, base, depth asc, itemid
我想要这样的结果:

class      itemid     parent     base     depth
myclass     item1     null      item3        -2
myclass     item2     item1     item3        -1
myclass     item3     item2     item3        0
myclass     item4     item3     item3        1
myclass     item5     item5     item3        2
如果上面的SQL被运行,我就可以很好地处理这些问题。现在,如果我删除注释,它似乎是在一个无限循环上。一定有办法做到这一点。
我可以从一个方向(祖先或子代)很好地获得结果,但无法在一个查询中同时获得这两个结果。
有人试过那样的东西吗


谢谢

在评论的查询中,您必须提到parent.parent为空

请检查一下


如果您不介意使用两个
WITH
语句,下面将返回整个层次结构树

测试数据

DECLARE @item TABLE (
  class VARCHAR(32)
  , itemid VARCHAR(32)
  , parent VARCHAR(32)
)

INSERT INTO @item VALUES 
  ('myclass', 'item1', null)  
  , ('myclass', 'item2', 'item1')  
  , ('myclass', 'item3', 'item2')    
  , ('myclass', 'item4', 'item3')    
  , ('myclass', 'item5', 'item4')    
SQL语句

;WITH children AS (
  SELECT  class
          , itemid
          , parent
          , base = itemid
          , depth = 0
  FROM    @item
  WHERE   class = 'myclass'
          AND itemid = 'item3'          
  UNION ALL
  SELECT  children.class
          , i.itemid
          , i.parent
          , children.base
          , children.depth + 1
  FROM    children
          INNER JOIN @item i ON i.parent = children.itemid
                                AND i.class = children.class
)
, parents AS (
  SELECT  *
  FROM    children
  WHERE   depth = 0
  UNION ALL
  SELECT  parents.class
          , i.itemid
          , i.parent
          , parents.base
          , parents.depth - 1
  FROM    parents
          INNER JOIN @item i ON i.itemid = parents.parent
                                AND i.class = parents.class                                  
)
SELECT  *
FROM    children
UNION 
SELECT  *
FROM    parents
ORDER BY depth
使用3个CTE

with 
ancestors as (...)
,children as (...)
,all_ as (select * from ancestors union all select * from children)
select * from all_

谢谢,但不是那样。我知道一个元素,它可以是层次结构中的根、分支或叶。我需要获取其整个层次结构。是否允许多个父级?这是一个有向无环图吗?我们是否可以假设item5将item4作为父项(根据您的示例,io item5)。
with 
ancestors as (...)
,children as (...)
,all_ as (select * from ancestors union all select * from children)
select * from all_