我叫毕加索 2017-06-14 00:29 采纳率: 100%
浏览 871
已采纳

oracle如果机构编码为空,则去上一级机构

oracle如果机构编码为空,则去上一级机构

表 A
字段 id 姓名 机构 机构编码
1 A 101 AC0000001
2 B 102

3 C 102

机构表 ID 机构号 上一级机构 名称 机构层级 机构编码
1 102 101 风险-部 3
2 101 99 风险部 2 AC0000001
3 99 总公司 1 AC0000000

请问大神,咋样才能通过update,才能将表A的的机构编码为空的数据,取上一级机构编码?请大神指教或提示。

  • 写回答

2条回答 默认 最新

  • 战在春秋 2017-06-14 01:40
    关注

    可以这样:

    UPDATE A   
    SET  机构编码 =   CASE  
                                                                    WHEN  机构编码 is null THEN 
                                                                                (select  机构编码 from 机构表 where  上一级机构 =
                                                                                      (select  上一级机构 from 机构表 where  机构 = 机构表. 机构号)  
                                                                                )
                                                                    ELSE  机构编码
                                                        END 
    

    代码不算复杂,就不加注释了,表名和字段名是按照题目描述写的,如报错,请检查修改。

    用心回答每个问题,如果对您有帮助,请采纳答案好吗,谢谢!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已采纳回答 12月13日

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 如何将下列的“无限压缩存储器”设计出来
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口