首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >甲骨文案条款

甲骨文案条款
EN

Stack Overflow用户
提问于 2022-05-30 12:07:49
回答 2查看 45关注 0票数 0

我需要在UPDATE语句WHERE子句中有一个CASE语句。但是,它给了我一个编译错误:

代码语言:javascript
复制
   UPDATE......
   .
   .
   WHERE CASE
           WHEN p_client_id = 0 THEN user_id = p_user_id
           ELSE client_id = p_client_id
         END;

680/50   PL/SQL: ORA-00905: missing keyword

我是不是遗漏了什么,或者这不是正确的语法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-05-30 12:20:26

我建议你这样改写它:

代码语言:javascript
复制
   UPDATE......
   .
   .
   WHERE (    p_client_id  = 0 and user_id   = p_user_id
           OR p_client_id != 0 and client_id = p_client_id )
         ;

我的假设(基于最初的问题)是p_client_id总是被填充。如果不是这样,那么您将需要修改此代码来处理空值。

票数 0
EN

Stack Overflow用户

发布于 2022-05-30 13:25:20

一个选项是使用DECODE()函数进行有条件的匹配,例如

代码语言:javascript
复制
WHERE DECODE(p_client_id,0,user_id,client_id)=DECODE(p_client_id,0,p_user_id,p_client_id)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72434078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档