91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle使用NOT IN條件查詢會遇到什么坑

發布時間:2021-12-04 09:46:17 來源:億速云 閱讀:199 作者:小新 欄目:大數據

小編給大家分享一下Oracle使用NOT IN條件查詢會遇到什么坑,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

劇情還原:

上周投產之后同事應該在某個頁面查詢的時候新增了一個not in的條件,結果導致列表部分數據不展示了,經排查發現原來是not in條件的問題。

問題復現:

1.基礎數據: 共10條數據  狀態為空-1條  已作廢-4條 報告審批-5條

select * from v_safe_testengineer v where v.vst_tester ='w07387';

Oracle使用NOT IN條件查詢會遇到什么坑

2.新增not in ‘已作廢’條件之后:共5條數據  報告審批-5條  什么情況?狀態為空的數據怎么不見了?

select * from v_safe_testengineer v where v.vst_tester ='w07387' and v.vst_note not in '已作廢';

Oracle使用NOT IN條件查詢會遇到什么坑

預期結果:共6條數據  狀態為空-1條  報告審批-5條

解決方案:

3.改進SQL之后:與預期結果一致

select * from v_safe_testengineer v where v.vst_tester ='w07387' and (v.vst_note not in '已作廢' or v.vst_note is null );

Oracle使用NOT IN條件查詢會遇到什么坑

ps:這種方案也能解決該問題,但是大家都知道Oracle in 超過1000個參數會報 “ORA-01795: 列表中的最大表達式數為 1000”

4.最終方案>達到預期結果

select * from v_safe_testengineer v where v.vst_tester ='w07387' and not exists (select a.id from v_safe_testengineer a where a.vst_tester ='w07387' and a.vst_note = '已作廢' and a.id = v.id)

Oracle使用NOT IN條件查詢會遇到什么坑

    大家拼接SQL條件的時候如果字段值有NULL的情況不要使用not in 這種方式,還是建議大家使用 not exists 和 exists ,相對來說效率高一點。

以上是“Oracle使用NOT IN條件查詢會遇到什么坑”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

迭部县| 辽阳市| 泊头市| 凤庆县| 和静县| 张家界市| 康定县| 都昌县| 石狮市| 鸡西市| 丰县| 米脂县| 东源县| 安达市| 开江县| 安泽县| 乐陵市| 平凉市| 如东县| 金阳县| 四会市| 宁强县| 巴里| 岱山县| 株洲县| 合山市| 大英县| 荔波县| 保康县| 宜城市| 杨浦区| 资溪县| 清水河县| 额尔古纳市| 仁寿县| 霍林郭勒市| 土默特右旗| 乌苏市| 安阳县| 咸阳市| 苍南县|