真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

專注于為中小企業(yè)提供成都網(wǎng)站制作、網(wǎng)站設(shè)計、外貿(mào)網(wǎng)站建設(shè)服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)卡若免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

劇情還原:

上周投產(chǎn)之后同事應(yīng)該在某個頁面查詢的時候新增了一個not in的條件,結(jié)果導(dǎo)致列表部分數(shù)據(jù)不展示了,經(jīng)排查發(fā)現(xiàn)原來是not in條件的問題。

問題復(fù)現(xiàn):

1.基礎(chǔ)數(shù)據(jù): 共10條數(shù)據(jù)  狀態(tài)為空-1條  已作廢-4條 報告審批-5條

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

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

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

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

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

預(yù)期結(jié)果:共6條數(shù)據(jù)  狀態(tài)為空-1條  報告審批-5條

解決方案:

3.改進SQL之后:與預(yù)期結(jié)果一致

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個參數(shù)會報 “ORA-01795: 列表中的最大表達式數(shù)為 1000”

4.最終方案>達到預(yù)期結(jié)果

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條件查詢會遇到什么坑”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


分享題目:Oracle使用NOTIN條件查詢會遇到什么坑
網(wǎng)頁網(wǎng)址:http://weahome.cn/article/gojhgg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部