合并 SQL 中组织之间存在父子关系的相关组织记录

Combining related organisation records in SQL where there is a Parent-Child relationship between organisations

我正在尝试构建一个 table 数据用于 Yellowfin BI 报告。这样做的一个限制是不能创建临时 table,然后将其删除到数据库中。我正在从我无法控制的现有数据库中提取数据。我只能用SQL查询现有数据

我需要使用的源数据库中有两个 table。为了清楚起见,我简化了它们。第一个包含组织。它有一个 ORG_ID 列,其中包含每个组织的唯一 ID 和一个 PARENT_ORG_ID 列,指示哪个组织是列表中其他组织的母公司:

ORG_ID     PARENT_ORG_ID
1          Null
2          1
3          5
4          5
5          Null
6          1

使用上面的table我可以看到组织之间存在以下关系:

ORG_ID     RELATED_ORGANISATIONS
1          2 and 6
2          1 and 6
3          5 and 4
4          5 and 3
5          4 and 3
6          1 and 2

我不确定在查询中表示这些连接的最佳方式,因为我需要将这些关系用于第二个 table。

我的第二个 table 是一份组织名单和所欠款项:

ORG_ID     MONEY_OWED
1          5
2          10
3          0
4          15
5          20
6          5

我需要实现的是 table,我可以搜索任何单个 ORG_ID,并查看该组织和所有相关组织的组合数据。在我的例子中,这可能是一个结果 table 像这样:

ORG_ID     MONEY_OWED_BY_ALL_RELATED_ORGS
1          20
2          20
3          35
4          35
5          35
6          20

我在想我应该使用 CTE 来处理组织之间的关系,但我无法理解它。

如有任何帮助,我们将不胜感激!

对于您的特定示例,您可以使用:

select o.*,
       sum(mo.money_owed) over (partition by coalesce(o.parent_org_id, o.org_id)) as parent_owed
from organizations o left join
     money_owed mo
     on mo.org_id = o.org_id;

之所以可行,是因为您的组织只有一层深度 -- 这与您的示例数据一致。