oracle - ORACLE - 有条件地更新每一行(仅迭代表一次)
问题描述
我有以下 SELECT 语句:
SELECT COUNT(*) FROM EPS_PROPOSAL
WHERE NSF_CODE = 14 OR
NSF_CODE = 5 OR
NSF_CODE = 3 OR
NSF_CODE = 45 OR
NSF_CODE = 11 OR
NSF_CODE = 2 OR
NSF_CODE = 7 OR
NSF_CODE = 46 OR
NSF_CODE = 37 OR
NSF_CODE = 22 OR
NSF_CODE = 40 OR
NSF_CODE = 9 OR
NSF_CODE = 47 OR
NSF_CODE = 19 OR
NSF_CODE = 13 OR
NSF_CODE = 4 OR
NSF_CODE = 48 OR
NSF_CODE = 42 OR
NSF_CODE = 49 OR
NSF_CODE = 50 OR
NSF_CODE = 31 OR
NSF_CODE = 27 OR
NSF_CODE = 10 OR
NSF_CODE = 41 OR
NSF_CODE = 39 OR
NSF_CODE = 35 OR
NSF_CODE = 21;
1 COUNT(*) = 902
现在,如果我尝试使用以下 UPDATE 语句遍历 EPS_PROPOSAL 表:
UPDATE EPS_PROPOSAL
SET NSF_CODE = (CASE WHEN NSF_CODE = 14 THEN 3
WHEN NSF_CODE = 5 THEN 4
WHEN NSF_CODE = 3 THEN 5
WHEN NSF_CODE = 45 THEN 7
WHEN NSF_CODE = 11 THEN 8
WHEN NSF_CODE = 2 THEN 9
WHEN NSF_CODE = 7 THEN 11
WHEN NSF_CODE = 46 THEN 12
WHEN NSF_CODE = 37 THEN 13
WHEN NSF_CODE = 22 THEN 14
WHEN NSF_CODE = 40 THEN 41
WHEN NSF_CODE = 9 THEN 19
WHEN NSF_CODE = 47 THEN 20
WHEN NSF_CODE = 19 THEN 21
WHEN NSF_CODE = 13 THEN 2
WHEN NSF_CODE = 4 THEN 22
WHEN NSF_CODE = 48 THEN 23
WHEN NSF_CODE = 42 THEN 24
WHEN NSF_CODE = 49 THEN 25
WHEN NSF_CODE = 50 THEN 27
WHEN NSF_CODE = 31 THEN 29
WHEN NSF_CODE = 27 THEN 31
WHEN NSF_CODE = 10 THEN 34
WHEN NSF_CODE = 41 THEN 35
WHEN NSF_CODE = 39 THEN 37
WHEN NSF_CODE = 35 THEN 38
WHEN NSF_CODE = 21 THEN 39 END);
1,866 rows updated.
看来我的 UPDATE 语句多次遍历我的表以完成工作,但我试图一次通过表 1 行并在满足其中一个条件时更新每一行 - 否则,我将覆盖我之前更新的东西。
底线 - 我应该只看到 902 行更新。
有什么建议么?
解决方案
问题似乎不是该表被多次读取。您的UPDATE
语句没有WHERE
子句,因此无论nsf_code
值如何,它都会更新表中的每一行。如果要更新行的子集,则需要包含一个WHERE
子句
UPDATE eps_proposal
SET nsf_code = (CASE ...)
WHERE nsf_code IN (14,5,3,...,21)
推荐阅读
- amazon-kinesis-kpl - KPL 是否支持代理配置?
- big-o - 三个嵌套循环的大 O 复杂度以及 if 语句中的最后一个循环
- swift - WKWebView 已失效" UserInfo={NSLocalizedDescription=WKWebView 已失效
- socrata - 如何找出我的服务器被阻止的原因
- c# - 存储一个没有服务定位器的 Unity 依赖注入容器
- tfs - 从 Team Foundation 服务帐户组中删除非活动用户
- r - 在 R 的 1 个绘图区域中放置 4 个直方图
- typescript - 如何为 Angular 8 中的选项卡编写点击事件
- ionic-framework - 按类别过滤产品
- asp.net - 如何对在 localhost 上运行的 .NET 项目的 API 调用失败进行故障排除?