Oracle Case WHERE Clause



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

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

我错过了什么,还是这不是正确的语法?

我建议你这样写:

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总是被填充的。如果不是这样,那么你需要修改这段代码来处理null。

一种选择是使用DECODE()函数有条件地匹配,例如

WHERE DECODE(p_client_id,0,user_id,client_id)=DECODE(p_client_id,0,p_user_id,p_client_id)

相关内容

  • 没有找到相关文章