oracle sql错误案例当其他时候(oracle sql error Case When Then Else)

系统教程 行业动态 更新时间:2024-06-14 16:59:22
oracle sql错误案例当其他时候(oracle sql error Case When Then Else) SELECT * FROM FirstTable WHERE RowProcessed = 'N' AND ( CASE WHEN EXISTS(SELECT top 1 FROM SecondTable) THEN 1 ELSE EXISTS( SELECT SecondTable.RowProcessed FROM SecondTable WHERE FirstTable.Key = SecondTable.Key AND SecondTable.RowProcessed = 'Y' ) END ) AND OtherConditions

Case当where else在where子句中。 不确定语法。

我想验证SecondTable中是否有行,如果有行检查另一个条件,那基本上就是我想要做的。

SELECT * FROM FirstTable WHERE RowProcessed = 'N' AND ( CASE WHEN EXISTS(SELECT top 1 FROM SecondTable) THEN 1 ELSE EXISTS( SELECT SecondTable.RowProcessed FROM SecondTable WHERE FirstTable.Key = SecondTable.Key AND SecondTable.RowProcessed = 'Y' ) END ) AND OtherConditions

Case When then else in where clause. Not sure about the syntax.

I would like to verify there are rows in the SecondTable and if there are rows check for another condition, that is basicallly what I want to do.

最满意答案

也许这就是你想要的? 如果SecondTable中有行,那么执行第二个EXISTS :

SELECT * FROM FirstTable WHERE RowProcessed = 'N' AND (NOT EXISTS (SELECT 1 from SecondTable) OR EXISTS (SELECT 1 FROM SecondTable WHERE FirstTable.Key = SecondTable.Key and SecondTable.RowProcessed = 'Y')) AND OtherConditions

Perhaps this is what you want? If there are rows in SecondTable, then do the second EXISTS:

SELECT * FROM FirstTable WHERE RowProcessed = 'N' AND (NOT EXISTS (SELECT 1 from SecondTable) OR EXISTS (SELECT 1 FROM SecondTable WHERE FirstTable.Key = SecondTable.Key and SecondTable.RowProcessed = 'Y')) AND OtherConditions

更多推荐

本文发布于:2023-04-16 19:06:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/dzcp/ccd1fe3ec96f7e5f9973b4ab197f7c57.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:错误   案例   sql   oracle   error

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!