亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

揭開SQL中NULL的神秘面紗

 更新時(shí)間:2023年01月04日 11:01:31   作者:六月·飛雪  
表的字段默認(rèn)允許存放NULL值,這意味著,您在插入記錄或者更新記錄時(shí),可以不為該字段指定值,此時(shí)該字段將存儲NULL值,這篇文章將揭開SQL中NULL的神秘面紗。這個(gè)問題可能困擾著很多初級開發(fā)者

這篇文章將揭開 SQL 中 NULL 的神秘面紗。這個(gè)問題可能困擾著很多初級開發(fā)者。

在查詢數(shù)據(jù)庫時(shí),如果你想知道一個(gè)列是否為 NULL,SQL 查詢語句該怎么寫呢?

是不是這樣:

SELECT * FROM SOME_TABLE
WHERE SOME_COLUMN = NULL

或者這樣寫:

SELECT * FROM SOME_TABLE
WHERE SOME_COLUMN IS NULL

正確的寫法應(yīng)該是第二種(WHERE SOME_COLUMN IS NULL)。

為什么要這樣寫?

在進(jìn)行數(shù)據(jù)庫數(shù)據(jù)比較操作時(shí),我們不會使用“IS”關(guān)鍵詞,不是嗎?

例如,如果我們想要知道一個(gè)列的值是否等于 1,WHERE 語句是這樣的:

WHERE SOME_COLUMN = 1

那為什么 NULL 值要用 IS 關(guān)鍵字呢?為什么要以這種方式來處理 NULL?

因?yàn)椋?SQL 中,NULL 表示“未知”。也就是說,NULL 值表示的是“未知”的值。

1NULL 等于未知

在大多數(shù)數(shù)據(jù)庫中,NULl 和空字符串是有區(qū)別的。

但并不是所有數(shù)據(jù)庫都這樣,例如,Oracle 就不支持空字符串,它會把空字符串自動轉(zhuǎn)成 NULL 值。

在其他大多數(shù)數(shù)據(jù)庫里,NULL 值和字符串的處理方式是不一樣的:

  • 空字符串表示“沒有值”,這個(gè)值是已知的。
  • NULL 表示“未知值”,這個(gè)值是未知的。

這就好比我問了一個(gè)問題:“美國總統(tǒng)羅斯福的中間名是什么”?

  • 可能有人會回答說:“我不知道羅斯??偨y(tǒng)的中間名是什么”。對于這種情況,可以在數(shù)據(jù)庫中使用 MIDDLE_NAME 列來表示羅斯福的中間名,而這一列的值為 NULL。
  • 也可能有人會回答說:“羅斯??偨y(tǒng)沒有中間名。他的父母沒有給他取中間名,所以我知道羅斯??偨y(tǒng)確實(shí)沒有中間名”。對于這種情況,MIDDLE_NAME 列應(yīng)該是一個(gè)空字符串。

Oracle 比較特殊,兩個(gè)值都使用 NULL 來表示,而其他大多數(shù)數(shù)據(jù)庫會區(qū)分對待。

但只要記住 NULL 表示的是一個(gè)未知的值,那么在寫 SQL 查詢語句時(shí)就會得心應(yīng)手。

例如,如果你有一個(gè)這樣的查詢語句:

SELECT * FROM SOME_TABLE
WHERE 1 = 1

這個(gè)查詢會返回所有的行(假設(shè) SOME_TABLE 不是空表),因?yàn)楸磉_(dá)式“1=1”一定為 true。

如果我這樣寫:

SELECT * FROM SOME_TABLE
WHERE 1 = 0

表達(dá)式“1=0”是 false,這個(gè)查詢語句不會返回任何數(shù)據(jù)。

但如果我寫成這樣:

SELECT * FROM SOME_TABLE
WHERE 1 = NULL

這個(gè)時(shí)候,數(shù)據(jù)庫不知道這兩個(gè)值(1 和 NULL)是否相等,所以它也不會返回任何數(shù)據(jù)。

2三元邏輯

SQL 查詢語句中的 WHERE 一般會有三種結(jié)果:

  • 它可以是 true(這個(gè)時(shí)候會返回?cái)?shù)據(jù));
  • 它可以是 false(這個(gè)時(shí)候不會返回?cái)?shù)據(jù));
  • 它也可以是 NULL 或未知(這個(gè)時(shí)候也不會返回?cái)?shù)據(jù))。

你可能會想:“既然這樣,那我為什么要去關(guān)心是 false 還是 NULL?它們不是都不會返回?cái)?shù)據(jù)嗎?”

接下來,我來告訴你在哪些情況下會有問題:我們來看看 NOT()。

假設(shè)有這樣的一個(gè)查詢語句:

SELECT * FROM SOME_TABLE
WHERE NOT(1 = 1)

數(shù)據(jù)庫首先會計(jì)算 1=1,這個(gè)顯然是 true。

接著,數(shù)據(jù)庫會應(yīng)用 NOT() 條件,所以 WHERE 返回 false。

所以,上面的查詢不會返回任何數(shù)據(jù)。

但如果把語句改成這樣:

SELECT * FROM SOME_TABLE
WHERE NOT(1 = 0)

數(shù)據(jù)庫首先會計(jì)算 1=0,這個(gè)肯定是 false。

接著,數(shù)據(jù)庫應(yīng)用 NOT() 條件,這樣就得到相反的結(jié)果,變成了 true。

所以,這個(gè)語句會返回?cái)?shù)據(jù)。

但如果把語句再改成下面這樣呢?

SELECT * FROM SOME_TABLE
WHERE NOT(1 = NULL)

數(shù)據(jù)庫首先計(jì)算 1=NULL,它不知道 1 是否等于 NULL,因?yàn)樗恢?NULL 的值是什么。

所以,這個(gè)計(jì)算不會返回 true,也不會返回 false,它會返回一個(gè) NULL。

接下來,NOT() 會繼續(xù)解析上一個(gè)計(jì)算返回的結(jié)果。

當(dāng) NOT() 遇到 NULL,它會生成另一個(gè) NULL。未知的相反面是另一個(gè)未知。

所以,對于這兩個(gè)查詢:

SELECT * FROM SOME_TABLE
WHERE NOT(1 = NULL)

SELECT * FROM SOME_TABLE
WHERE 1 = NULL

都不會返回?cái)?shù)據(jù),盡管它們是完全相反的。

3NULL 和 NOT IN

如果我有這樣的一個(gè)查詢語句:

SELECT * FROM SOME_TABLE
WHERE 1 IN (1, 2, 3, 4, NULL)

很顯然,WHERE 返回 true,這個(gè)語句將返回?cái)?shù)據(jù),因?yàn)?1 在括號列表里是存在的。

但如果這么寫:

SELECT * FROM SOME_TABLE
WHERE 1 NOT IN (1, 2, 3, 4, NULL)

很顯然,WHERE 返回 false,這個(gè)查詢不會返回?cái)?shù)據(jù),因?yàn)?1 在括號列表里存在,但我們說的是“NOT IN”。

但如果我們把語句改成這樣呢?

SELECT * FROM SOME_TABLE
WHERE 5 NOT IN (1, 2, 3, 4, NULL)

這里的 WHRE 不會返回?cái)?shù)據(jù),因?yàn)樗慕Y(jié)果不是 true。數(shù)字 5 在括號列表里可能不存在,也可能存在,因?yàn)楫?dāng)中有一個(gè) NULL 值(數(shù)據(jù)庫不知道 NULL 的值是什么)。

這個(gè) WHERE 會返回 NULL,所以整個(gè)查詢不會返回任何數(shù)據(jù)。

希望你們現(xiàn)在都清楚該怎么在 SQL 語句中處理 NULL 值了。

到此這篇關(guān)于揭開SQL中NULL的神秘面紗的文章就介紹到這了,更多相關(guān)SQL NULL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 中存在null和空時(shí)創(chuàng)建唯一索引的方法

    mysql 中存在null和空時(shí)創(chuàng)建唯一索引的方法

    據(jù)庫默認(rèn)值都有null,此時(shí)創(chuàng)建唯一索引時(shí)要注意了,此時(shí)數(shù)據(jù)庫會把空作為多個(gè)重復(fù)值
    2014-10-10
  • MySQL主從同步機(jī)制與同步延時(shí)問題追查過程

    MySQL主從同步機(jī)制與同步延時(shí)問題追查過程

    這篇文章主要給大家介紹了關(guān)于MySQL主從同步機(jī)制與同步延時(shí)問題追查的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • MySQL 升級方法指南大全

    MySQL 升級方法指南大全

    通常,從一個(gè)發(fā)布版本升級到另一個(gè)版本時(shí),我們建議按照順序來升級版本。例如,想要升級 MySQL 3.23 時(shí),先升級到 MySQL 4.0,而不是直接升級到 MySQL 4.1 或 MySQL 5.0。
    2008-01-01
  • mysql存儲過程 在動態(tài)SQL內(nèi)獲取返回值的方法詳解

    mysql存儲過程 在動態(tài)SQL內(nèi)獲取返回值的方法詳解

    本篇文章是對mysql存儲過程在動態(tài)SQL內(nèi)獲取返回值進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • mysql.help_topic生成序列的方法實(shí)現(xiàn)

    mysql.help_topic生成序列的方法實(shí)現(xiàn)

    本文探討了如何使用MySQL的help_topic表生成序列,并介紹了相應(yīng)的SQL查詢語句和實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • Mysql 數(shù)據(jù)庫死鎖過程分析(select for update)

    Mysql 數(shù)據(jù)庫死鎖過程分析(select for update)

    最近有項(xiàng)目需求,需要保證多臺機(jī)器不拿到相同的數(shù)據(jù),后來發(fā)現(xiàn)Mysql查詢語句使用select.. for update經(jīng)常導(dǎo)致數(shù)據(jù)庫死鎖問題,下面小編給大家介紹mysql 數(shù)據(jù)庫死鎖過程分析(select for update),對mysql數(shù)據(jù)庫死鎖問題感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • Mysql自帶profiling性能分析工具使用分享

    Mysql自帶profiling性能分析工具使用分享

    Mysql自帶profiling性能分析工具使用分享,需要的朋友可以參考下
    2012-11-11
  • MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù)

    MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù)

    這篇文章主要介紹了MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù),幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • mysql連接的空閑時(shí)間超過8小時(shí)后 MySQL自動斷開該連接解決方案

    mysql連接的空閑時(shí)間超過8小時(shí)后 MySQL自動斷開該連接解決方案

    MySQL 的默認(rèn)設(shè)置下,當(dāng)一個(gè)連接的空閑時(shí)間超過8小時(shí)后,MySQL 就會斷開該連接,而 c3p0 連接池則以為該被斷開的連接依然有效。在這種情況下,如果客戶端代碼向 c3p0 連接池請求連接的話,連接池就會把已經(jīng)失效的連接返回給客戶端,客戶端在使用該失效連接的時(shí)候即拋出異常
    2012-11-11
  • 30種SQL語句優(yōu)化的方法匯總

    30種SQL語句優(yōu)化的方法匯總

    這篇文章從30個(gè)方面,分享了sql優(yōu)化的一些小技巧,希望對你有所幫助,需要的朋友可以參考下
    2022-10-10

最新評論