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

MySQL中的性別字段到底加不加索引

 更新時間:2024年04月11日 09:06:14   作者:chengxunzun  
這篇文章主要介紹了MySQL中的性別字段到底加不加索引問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

準備

首先針對MySQL 性別字段到底加不加索引,其實按照創(chuàng)建索引的原則之一 區(qū)別度高的情況下才會使用索引,為什么?

區(qū)別度低難道就不能使用索引?區(qū)別度低難道使得索引失效了嗎?

給MySQL的性別字段添加索引,MySQL到底是否會使用?

環(huán)境

MySQL 5.7 & MySQL8.0 兩個版本最常用的,如果得到的結論是一致的,那么就摒棄版本不一樣的問題。

MySQL8.0 t1 數據量100w ;MySQL5.7 sys_user 10w

測試

MySQL8.0, 不加索引查詢 ,select * from t1 where sex = ‘男’ ,耗時0.624s ,可以看到是全表掃描

MySQL8.0, 性別 加索引查詢 ,select * from t1 where sex = ‘男’ ,耗時1.305s,可以看到使用到了索引,并不是索引失效

MySQL5.7, 不加索引查詢 ,select * from t1 where sex = ‘男’ ,耗時1.006s,可以看到是全表掃描

MySQL5.7, 加索引查詢 ,select * from t1 where sex = ‘男’ ,耗時 1.098s,可以看到使用到了索引

總結

MySQL 性別字段到底加不加索引,實際上與索引創(chuàng)建規(guī)則之一 區(qū)分度有關,性別字段假設有100w數據,50w男、50w女

區(qū)別度幾乎等于 0 , select count(DISTINCT sex)/count(*) from sys_user ,實際上對于性別字段不適合創(chuàng)建索引,是因為select * 操作,還得進行50w次回表操作

根據主鍵從聚簇索引中找到其他字段 ,這一部分開銷從上面的測試來說還是比較大的,所以從性能角度來看 不建議性別字段加索引,加上索引并不是索引失效,而是回表操作使得變慢的

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解MySQL 數據分組

    詳解MySQL 數據分組

    這篇文章主要介紹了MySQL 數據分組的相關資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-12-12
  • MySQL索引的5種應用

    MySQL索引的5種應用

    本文主要介紹了MySQL索引的5種應用,包含聚集索引,唯一索引,非唯一(普通)索引,全文索引,組合索引等,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • windows下mysql 8.0.16 安裝配置方法圖文教程

    windows下mysql 8.0.16 安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了windows下mysql 8.0.16 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • 解決出現(xiàn)secure_file_priv null的問題

    解決出現(xiàn)secure_file_priv null的問題

    這篇文章主要介紹了解決出現(xiàn)secure_file_priv null的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • MYSQL字符串強轉的方法示例

    MYSQL字符串強轉的方法示例

    這篇文章主要給大家介紹了關于MYSQL字符串強轉的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • MySQL學習筆記2:數據庫的基本操作(創(chuàng)建刪除查看)

    MySQL學習筆記2:數據庫的基本操作(創(chuàng)建刪除查看)

    我們所安裝的MySQL說白了是一個數據庫的管理工具,真正有價值的東西在于數據關系型數據庫的數據是以表的形式存在的,N個表匯總在一起就成了一個數據庫現(xiàn)在來看看數據庫的基本操作
    2013-01-01
  • MySQL觸發(fā)器實現(xiàn)兩表數據同步的代碼詳解

    MySQL觸發(fā)器實現(xiàn)兩表數據同步的代碼詳解

    在數據庫應用中,我們經常需要對數據進行某些操作,并在操作完成后進行相應的處理,這時候,可以使用觸發(fā)器來實現(xiàn)這些功能,MySQL提供了強大的觸發(fā)器功能,本文將給大家詳細介紹MySQL觸發(fā)器實現(xiàn)兩表數據同步,需要的朋友可以參考下
    2023-12-12
  • 將圖片保存到mysql數據庫并展示在前端頁面的實現(xiàn)代碼

    將圖片保存到mysql數據庫并展示在前端頁面的實現(xiàn)代碼

    這篇文章主要介紹了將圖片保存到mysql數據庫并展示在前端頁面,本文給的大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • MySQL臨時表的使用方法詳解

    MySQL臨時表的使用方法詳解

    在寫查詢時我們會經常用到臨時表來存儲數據,下面這篇文章主要給大家介紹了關于MySQL臨時表的使用方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • MySQL中count(distinct?col...)組合使用的注意要點詳解

    MySQL中count(distinct?col...)組合使用的注意要點詳解

    @count()是一個聚合函數,返回指定匹配條件的行數,開發(fā)中常用來統(tǒng)計表中數據、全部數據、不為null數據或者去重數據,這篇文章主要給大家介紹了關于MySQL中count(distinct?col...)組合使用的注意要點,需要的朋友可以參考下
    2024-08-08

最新評論