我叫毕加索 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 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题
  • ¥20 yolov5自定义Prune报错,如何解决?