桃花笑春风238 2021-06-23 16:40 采纳率: 0%
浏览 21

想问一个oracle数据库的语句

我写了一个关于资产负债表的存储过程。然后资产负债表有一级科目二级科目三级科目的这样子。有下级科目的zbmx等于0,没有下级科目的zbmx等于1。现在我想用一个语句实现:当没有任何下级科目时,对应的上级科目的zbmx等于1反之为0。怎么实现呢

 

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-14 21:37
    关注

    根据您描述的情况,您可以使用以下的SQL语句来实现您的需求:

    UPDATE 表名 SET zbmx = (SELECT COUNT(*) FROM 表名 WHERE 上级科目ID = 当前科目ID AND 下级科目ID > 当前科目ID) > 0 WHERE zbmx = 0;

    其中,表名为您资产负债表的表名,上级科目ID和下级科目ID为科目关联的字段名,当前科目ID为当前记录的科目ID,zbmx为您需要更新的字段。

    该语句的意思为,在表名中,如果当前记录的zbmx为0且没有任何下级科目,即当前记录的科目是最底层科目,则将其对应的上级科目的zbmx设为1,否则设为0。这里使用了一个子查询来计算当前科目有多少个下级科目,如果大于0,则说明该科目不是最底层科目。

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog