Oracle 案例 WHERE 子句

兰登统计

我需要在我的 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是总是填充的。如果不是这种情况,那么您将需要修改此代码以处理空值。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章