SQLite 實(shí)現(xiàn)if not exist 類(lèi)似功能的操作
需要實(shí)現(xiàn):
if not exists(select * from ErrorConfig where Type='RetryWaitSeconds') begin insert into ErrorConfig(Type,Value1) values('RetryWaitSeconds','3') end
只能用:
insert into ErrorConfig(Type,Value1) select 'RetryWaitSeconds','3' where not exists(select * from ErrorConfig where Type='RetryWaitSeconds')
因?yàn)?SQLite 中不支持SP
補(bǔ)充:sqlite3中NOT IN 不好用的問(wèn)題
在用sqlite3熟悉SQL的時(shí)候遇到了一個(gè)百思不得其解的問(wèn)題,也沒(méi)有在google上找到答案。雖然最后用“迂回”的方式碰巧解決了這個(gè)問(wèn)題,但暫時(shí)不清楚原理是什么,目前精力有限,所以暫時(shí)記錄下來(lái),有待繼續(xù)研究。
數(shù)據(jù)庫(kù)是這樣的:
CREATE TABLE book ( id integer primary key, title text, unique(title) ); CREATE TABLE checkout_item ( member_id integer, book_id integer, movie_id integer, unique(member_id, book_id, movie_id) on conflict replace, unique(book_id), unique(movie_id) ); CREATE TABLE member ( id integer primary key, name text, unique(name) ); CREATE TABLE movie ( id integer primary key, title text, unique(title) );
該數(shù)據(jù)庫(kù)包含了4個(gè)表:book, movie, member, checkout_item。其中,checkout_item用于保存member對(duì)book和movie的借閱記錄,屬于關(guān)系表。
問(wèn)一:哪些member還沒(méi)有借閱記錄?
SQL語(yǔ)句(SQL1)如下:
SELECT * FROM member WHERE id NOT IN(SELECT member_id FROM checkout_item);
得到了想要的結(jié)果。
問(wèn)二:哪些book沒(méi)有被借出?
這看起來(lái)與上一個(gè)是類(lèi)似的,于是我理所當(dāng)然地運(yùn)行了如下的SQL語(yǔ)句(SQL2):
SELECT * FROM book WHERE id NOT IN(SELECT book_id FROM checkout_item);
可是——運(yùn)行結(jié)果沒(méi)有找到任何記錄! 我看不出SQL2與SQL1這兩條語(yǔ)句有什么差別,難道是book表的問(wèn)題?于是把NOT去掉,運(yùn)行了如下查詢(xún)語(yǔ)句:
SELECT * FROM book WHERE id IN(SELECT book_id FROM checkout_item);
正確返回了被借出的book,其數(shù)量小于book表里的總行數(shù),也就是說(shuō)確實(shí)是有book沒(méi)有借出的。
接著google(此處省略沒(méi)有營(yíng)養(yǎng)的字),沒(méi)找到解決方案??墒?,為什么member可以,book就不可以呢?它們之前有什么不同?仔細(xì)觀察,發(fā)現(xiàn)checkout_item里的book_id和movie_id都加了一個(gè)unique,而member_id則沒(méi)有。也許是這個(gè)原因?不用id了,換title試試:
SELECT * FROM book WHERE title NOT IN( SELECT title FROM book WHERE id IN( SELECT book_id FROM checkout_item));
確實(shí)很迂回,但至少work了。。。
問(wèn)題原因:當(dāng)NOT碰上NULL
事實(shí)是,我自己的解決方案只不過(guò)是碰巧work,這個(gè)問(wèn)題產(chǎn)生跟unique沒(méi)有關(guān)系。邱俊濤的解釋是,“SELECT book_id FROM checkout_item”的結(jié)果中含有null值,導(dǎo)致NOT也返回null。當(dāng)一個(gè)member只借了movie而沒(méi)有借book時(shí),產(chǎn)生的checkout_item中book_id就是空的。
解決方案是,在選擇checkout_item里的book_id時(shí),把值為null的book_id去掉:
SELECT * FROM book WHERE id NOT IN(SELECT book_id FROM checkout_item WHERE book_id IS NOT NULL);
總結(jié)
我在解決這個(gè)問(wèn)題的時(shí)候方向是不對(duì)的,應(yīng)該像調(diào)試程序一樣,去檢查中間結(jié)果。比如,運(yùn)行如下語(yǔ)句,結(jié)果會(huì)包含空行:
SELECT book_id FROM checkout_item
而運(yùn)行下列語(yǔ)句,結(jié)果不會(huì)包含空行:
SELECT member_id FROM checkout_item
這才是SQL1與SQL2兩條語(yǔ)句執(zhí)行過(guò)程中的差別。根據(jù)這個(gè)差別去google,更容易找到答案。當(dāng)然了,沒(méi)有NULL概念也是我“百思不得其解”的原因。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
初識(shí)SQLITE3數(shù)據(jù)庫(kù)
本文主要講訴Sqlite數(shù)據(jù)庫(kù)的一些基本概念以及SQLite的優(yōu)勢(shì),需要的朋友可以參考下2014-08-08Win11下基于VS2022編譯SQLite3源碼的實(shí)現(xiàn)步驟
本文主要介紹了Win11下基于VS2022編譯SQLite3源碼的實(shí)現(xiàn)步驟,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09python之sqlalchemy創(chuàng)建表的實(shí)例詳解
這篇文章主要介紹了數(shù)據(jù)庫(kù)之sqlalchemy創(chuàng)建表的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家掌握理解這部分內(nèi)容,需要的朋友可以參考下2017-10-10SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)詳解
這篇文章主要介紹了SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-03-03Sqlite數(shù)據(jù)庫(kù)里插入數(shù)據(jù)的條數(shù)上限是500
sqlite每次只能插入的數(shù)據(jù)不能超過(guò)500條數(shù)據(jù),大家在使用的時(shí)候需要注意一下。2015-04-04SQLite教程(十三):C語(yǔ)言編程實(shí)例代碼(1)
這篇文章主要介紹了SQLite教程(十三):C語(yǔ)言編程實(shí)例代碼(1),本文講解了獲取表的Schema信息、動(dòng)態(tài)創(chuàng)建表、刪除該表、常規(guī)數(shù)據(jù)插入、創(chuàng)建測(cè)試數(shù)據(jù)表、刪除測(cè)試表等內(nèi)容,需要的朋友可以參考下2015-05-05SQLite學(xué)習(xí)手冊(cè)(SQLite在線(xiàn)備份)
在SQLite中提供了一組用于在線(xiàn)數(shù)據(jù)庫(kù)備份的APIs函數(shù)(C接口),可以很好的解決上述方法存在的不足。通過(guò)該組函數(shù),可以將源數(shù)據(jù)庫(kù)中的內(nèi)容拷貝到另一個(gè)數(shù)據(jù)庫(kù),同時(shí)覆蓋目標(biāo)數(shù)據(jù)庫(kù)中的數(shù)據(jù)2013-12-12SQLite教程(五):索引和數(shù)據(jù)分析/清理
這篇文章主要介紹了SQLite教程(五):索引和數(shù)據(jù)分析/清理,本文講解了創(chuàng)建索引、刪除索引、重建索引、數(shù)據(jù)分析、數(shù)據(jù)清理等內(nèi)容,需要的朋友可以參考下2015-05-05sQlite常用語(yǔ)句以及sQlite developer的使用與注冊(cè)
sQlite數(shù)據(jù)庫(kù)對(duì)大家來(lái)說(shuō)應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于sQlite常用語(yǔ)句以及sQlite developer使用與注冊(cè)的相關(guān)資料,文中通過(guò)示例代碼與圖片給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,下面來(lái)一起看看吧。2017-10-10