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的的机构编码为空的数据,取上一级机构编码?请大神指教或提示。
可以这样:
UPDATE A
SET 机构编码 = CASE
WHEN 机构编码 is null THEN
(select 机构编码 from 机构表 where 上一级机构 =
(select 上一级机构 from 机构表 where 机构 = 机构表. 机构号)
)
ELSE 机构编码
END
代码不算复杂,就不加注释了,表名和字段名是按照题目描述写的,如报错,请检查修改。
用心回答每个问题,如果对您有帮助,请采纳答案好吗,谢谢!
排版错误,重新发:
UPDATE A
SET 机构编码 = CASE
WHEN 机构编码 is null THEN
(select 机构编码 from 机构表 where 上一级机构 =
(select 上一级机构 from 机构表 where 机构 = 机构表. 机构号)
)
ELSE 机构编码
END