Oracle SQL查询层次结构计数

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (35)

我有2个表1-部门(一些部门是其他部门的一部分)。 2名员工,在部门工作

WITH `d1` AS (
      SELECT 1 ID, 'dep1' NAME,    null Parent_id UNION ALL
      SELECT 2, 'dep2',           null             UNION ALL
      SELECT 3, 'dep21',  2                UNION ALL
      SELECT 4,'dep22',                 2 
    )
WITH `d2` AS (
  SELECT 1 ID, 'Name1' NAME,    3 DEP_id UNION ALL
  SELECT 2,         'Name2',    4             UNION ALL
  SELECT 3,         'Name3',     1               UNION ALL
  SELECT 4,         'Name4',    2             UNION ALL

我需要找到每个部门的员工人数,包括父母。我想我必须使用“connect by”功能,但我不知道如何使用它。结果是:

ID  Qty
1   1
2   3
3   1
4   1
提问于
用户回答回答于

如您所怀疑,需要CONNECT BY。 诀窍是省略START WITH子句,因此每个部门都被视为“根”。 然后,我们可以计算每个“root”的员工 - 即每个部门及其所有子部门。

这是你的例子。 我还为您的部门结构添加了一个额外的级别,作为一个更高级的测试用例。

WITH dept ( id, name, parent_id) AS (
      SELECT 1, 'dep1', null FROM DUAL UNION ALL
      SELECT 2, 'dep2', null FROM DUAL UNION ALL
      SELECT 3, 'dep21',  2 FROM DUAL  UNION ALL
      SELECT 4,'dep22', 2 FROM DUAL UNION ALL
      SELECT 5, 'dep211', 3 FROM DUAL
    ),
 emp (id, name, dep_id) AS (
  SELECT 1, 'Name1', 3 FROM DUAL UNION ALL
  SELECT 2, 'Name2', 4 FROM DUAL UNION ALL
  SELECT 3, 'Name3', 1 FROM DUAL  UNION ALL
  SELECT 4, 'Name4', 2 FROM DUAL UNION ALL 
  SELECT 5, 'Name5', 5 FROM DUAL
),
intermediate as (
select connect_by_root d.name deptname, level lvl, e.id empid, e.name empname
from dept d left join emp e on e.dep_id = d.id
-- Unfortunately, connecting this way, we cannot also determine the "level" of each 
-- department.  To do that, we would need the CONNECT BY to be reversed, i.e.,: 
-- connect by prior d.parent_id = d.id
connect by d.parent_id = prior d.id
-- No "START WITH" clause
)
SELECT deptname, 
       count(empid) empcount,
       listagg(empname,', ') within group ( order by empname) emplist
FROM intermediate
GROUP BY deptname
ORDER BY deptname;

+----------+----------+----------------------------+ | DEPTNAME | EMPCOUNT | EMPLIST | +----------+----------+----------------------------+ | dep1 | 1 | Name3 | | dep2 | 4 | Name1, Name2, Name4, Name5 | | dep21 | 2 | Name1, Name5 | | dep211 | 1 | Name5 | | dep22 | 1 | Name2 | +----------+----------+----------------------------+

热门问答

能提供腾讯区块链TBaas技术上链对接的流程图吗?

您好,非常感谢您的建议,我们目前确实没有整理完整的流程图,我们会尽快补齐并上线。 文字版的流程您可以先参考一下: 1,梳理业务场景和流程 2,规划区块链网络规模 3,购买区块链节点、组建区块链网络 4,根据业务场景编写智能合约 5,应用系统调用区块链的智能合约,与链交互 如果...... 展开详请

关于云直播的几个问题,望大佬解惑?

学生路人
推荐

1 海外单独计费

2 地址都是自己算的 可以变也可以不变

3 这个接口是拉流转推的 ,和播放不是一个东西哈 。

腾讯加固助手不能下载了吗?下载地址在哪里?MAC可以下载吗?我看只能在网页上加固,自己签名。?

腾讯云@移动安全

腾讯 · 移动开发工程师 (已认证)

腾讯云移动安全前端开发
推荐

乐固客户端已下线,可以使用移动应用在线加固https://console.cloud.tencent.com/ms/reinforce/list

可以自行签名打渠道包。

一台服务器能绑定几个域名,我现在需要另外购买一台服务器目前已经有一台服务器并且绑定一个备案过的域名?

推荐
如果问“能绑定多少域名”,那可以绑定无限个。 如果问“能备案多少域名”,那也可以绑定无限个。 如果问“能绑定多少个备案主体名下的域名”,就需要科普了。 (1)一个腾讯云账号只能有一个主体的备案信息(主体即为个人或者单位)。所以有个东西叫做“备案授权码”,每个账号A申请授权码并发送...... 展开详请

我用spark多个特征处理算子对原始数据进行处理,最后通过决策树训练分类,请问怎么导出最终模型?

腾讯智能钛AI开发者

腾讯云 · 智能钛产品团队 (已认证)

腾讯智能钛产品团队官方运营账号。分享产品最新动态,第一时间解答用户疑问。
推荐

您好,如果是使用组件自己编写的代码,可以使用 spark 中的 pipeline 功能,将多个功能串成一个流水线,再把流水线导出为 pmml 模型。详见 https://github.com/jpmml/jpmml-sparkml。

TencentOS例程,keil5编译报错no such file or directory?

Supowang

腾讯 · 高级工程师 (已认证)

腾讯物联网操作系统TencentOS tiny产品接口人---岁寒知松柏,做最好的自己!
推荐
您好!您的代码是早期的代码,请使用最新的github代码,代码下载地址:https://github.com/Tencent/TencentOS-tiny 或者腾讯工蜂 https://git.code.tencent.com/Tencent_Open_Source/Tence...... 展开详请

所属标签

扫码关注云+社区

领取腾讯云代金券