欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中NULL對(duì)索引的影響深入講解

 更新時(shí)間:2019年07月04日 10:06:42   作者:CayChan  
這篇文章主要給大家介紹了關(guān)于MySQL中NULL對(duì)索引的影響的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

看了很多博客,也聽過(guò)很多人說(shuō),包括我們公司的DBA,說(shuō)MySql中如果某一列中含有null,那么包含該列的索引就無(wú)效了。

翻了下《高性能MySQL第二版》和《MySQL技術(shù)內(nèi)幕——InnoDB存儲(chǔ)引擎第2版》,并沒有看到關(guān)于這個(gè)的介紹。但在本地試了下,null列是可以用到索引的,不管是單列索引還是聯(lián)合索引,但僅限于is null,is not null是不走索引的。

后來(lái)在官方文檔中找到了說(shuō)明,如果某列字段中包含null,確實(shí)是可以使用索引的,地址:https://dev.mysql.com/doc/refman/5.7/en/is-null-optimization.html。

在mysql5.6和5.7下均可,存儲(chǔ)引擎為InnoDB。

數(shù)據(jù)如下:

1. 單列索引

給name列建單列索引:

查詢name為null的行:

查詢name為'test0'或?yàn)閚ull的行:

可以發(fā)現(xiàn)都可以用到索引。

2. 聯(lián)合索引

給age和name添加聯(lián)合索引:


查詢age為14并且name為null的行:

可以發(fā)現(xiàn)同樣用到了索引。

3. 其他

雖然MySQL可以在含有null的列上使用索引,但不代表null和其他數(shù)據(jù)在索引中是一樣的。

不建議列上允許為空。最好限制not null,并設(shè)置一個(gè)默認(rèn)值,比如0和''空字符串等,如果是datetime類型,可以設(shè)置成'1970-01-01 00:00:00'這樣的特殊值。

對(duì)MySQL來(lái)說(shuō),null是一個(gè)特殊的值,Conceptually, NULL means “a missing unknown value” and it is treated somewhat differently from other values。比如:不能使用=,<,>這樣的運(yùn)算符,對(duì)null做算術(shù)運(yùn)算的結(jié)果都是null,count時(shí)不會(huì)包括null行等,null比空字符串需要更多的存儲(chǔ)空間等。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • MySQL安裝失敗的原因及解決步驟

    MySQL安裝失敗的原因及解決步驟

    因很多同學(xué)安裝mysql總是出問(wèn)題,所以下面這篇文章主要給大家介紹了關(guān)于MySQL安裝失敗的原因及解決步驟,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • 在idea中如何操作MySQL數(shù)據(jù)庫(kù)

    在idea中如何操作MySQL數(shù)據(jù)庫(kù)

    這篇文章主要介紹了在idea中如何操作MySQL數(shù)據(jù)庫(kù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Mysql prepare預(yù)處理的具體使用

    Mysql prepare預(yù)處理的具體使用

    本文主要介紹了Mysql prepare預(yù)處理,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • MySQL索引失效十種場(chǎng)景與優(yōu)化方案

    MySQL索引失效十種場(chǎng)景與優(yōu)化方案

    這篇文章主要介紹了MySQL索引失效十種場(chǎng)景與優(yōu)化方案,文中有詳細(xì)的代碼示例供參考閱讀,感興趣的朋友可以看一下
    2023-05-05
  • MySQL ifnull()函數(shù)的具體使用

    MySQL ifnull()函數(shù)的具體使用

    本文主要介紹了MySQL ifnull()函數(shù)的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • MySQL從MyISAM轉(zhuǎn)換成InnoDB錯(cuò)誤與常用解決辦法

    MySQL從MyISAM轉(zhuǎn)換成InnoDB錯(cuò)誤與常用解決辦法

    由于一些程序的要求,需要MyISAM數(shù)據(jù)引擎或InnoDB,下面是具體的解決方法,經(jīng)測(cè)試偶爾會(huì)出現(xiàn)一些問(wèn)題。
    2011-05-05
  • mysql連接器之mysql-connector-java問(wèn)題

    mysql連接器之mysql-connector-java問(wèn)題

    這篇文章主要介紹了mysql連接器之mysql-connector-java問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)詳解

    Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)詳解

    對(duì)用戶來(lái)說(shuō),分區(qū)表是一個(gè)獨(dú)立的邏輯表,但是底層由多個(gè)物理子表組成,下面這篇文章主要給大家介紹了關(guān)于Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • MySQL存儲(chǔ)引擎InnoDB的配置與使用的講解

    MySQL存儲(chǔ)引擎InnoDB的配置與使用的講解

    今天小編就為大家分享一篇關(guān)于MySQL存儲(chǔ)引擎InnoDB的配置與使用的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03
  • mysql全文模糊搜索MATCH AGAINST方法示例

    mysql全文模糊搜索MATCH AGAINST方法示例

    這篇文章主要介紹了mysql全文模糊搜索MATCH AGAINST方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11

最新評(píng)論