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

MySQL索引總結(jié)(Index?Type)

 更新時(shí)間:2023年02月05日 12:15:36   作者:糖小豆子  
本文主要介紹了MySQL索引總結(jié)(Index?Type),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

MySQL Index

索引是一種數(shù)據(jù)結(jié)構(gòu),可以是B-tree、R-tree、或者h(yuǎn)ash結(jié)構(gòu)。其中,B-tree適用于查找某范圍內(nèi)的數(shù)據(jù),可以快速地從當(dāng)前數(shù)據(jù)找到嚇一跳數(shù)據(jù);R-tree常用于查詢比較接近的數(shù)據(jù);hash結(jié)構(gòu)適用于隨機(jī)訪問(wèn)場(chǎng)景,查找每條數(shù)據(jù)時(shí)間幾乎一致。

優(yōu)化查詢的有效方法是為經(jīng)常查詢的字段建立索引,如無(wú)索引查詢數(shù)據(jù)時(shí),會(huì)遍歷整張表;若建立索引后查找起來(lái)會(huì)更快速。當(dāng)進(jìn)行update、delete、insert操作時(shí),mysql會(huì)自動(dòng)更新索引信息。

1.創(chuàng)建和刪除索引

mysql> create index idx_name on tab_name ( col_name );

mysql> alter table tab_name ADD index idx_name ( col_name );

使用create index 需要制定索引名,而用alter table創(chuàng)建時(shí),可以不指定索引名,mysql會(huì)自動(dòng)生成索引名。
若不想用存儲(chǔ)引擎默認(rèn)索引類型,可以指定索引類型:

mysql> alter table tab_name ADD index idx_name ( col_name ) using btree;

2. 索引類型

Btree 適合連續(xù)讀取數(shù)據(jù)

  • Rtree 適合根據(jù)一條數(shù)據(jù) 找附近的數(shù)據(jù)
  • Hash 適合隨機(jī)讀取數(shù)據(jù)
  • FullText 全文索引,建立倒排索引,適用于判斷字段是否包含問(wèn)題,例如 like“%ss%”
  • Spatial 空間索引,是對(duì)空間數(shù)據(jù)類型的字段建立的索引

索引有如下幾種情況:

  • index索引:通常意義的索引
  • unique索引:唯一索引,保證了列不包含重復(fù)的值,對(duì)于多列唯一索引,它保證值的組合不重復(fù)。
  • primary key索引:unique索引的一種,一個(gè)表只能有一個(gè)primary key

MySQL提供多種索引供選擇:

普通索引
最基本的索引類型,沒(méi)有唯一性限制,通過(guò)以下方式創(chuàng)建:
創(chuàng)建索引:create index idx_name on tab_name (col_name);
修改表:Alter table tab_name add index idx_name (col_name);

唯一性索引
與普通索引的區(qū)別:索引列的所有值都只能出現(xiàn)一次,即必須唯一。唯一性索引通過(guò)以下方式創(chuàng)建:
創(chuàng)建索引 create unique index idx_name on tab_name (col_name);

主鍵
一種唯一性索引,一個(gè)表只有一個(gè)。
一般在創(chuàng)建表的時(shí)候指定:create table tab_name(…, primary key (col_name));

外鍵
一般Alter table構(gòu)建

全文索引
可以在varchar或者text類型列上創(chuàng)建。
通過(guò)alter table 或 create index命令創(chuàng)建全文索引要比記錄插入帶有全文索引的空表更快。

單列索引/多列索引
索引可以是單列索引,也可以是多列索引。為提高搜索效率,需要考慮使用多列索引。
Alter table tab_name add index idx_name (col_name1, col_name2, col_name3);
由于索引文件以B樹(shù)格式保存。MySQL可以立即找到合適的col_name1, 然后再轉(zhuǎn)到合適的col_name2, 最后轉(zhuǎn)到合適的col_name3。在沒(méi)有掃描數(shù)據(jù)文件任何一個(gè)記錄的情況下,MySQL可以正確地找出了搜索的目標(biāo)記錄。

最左前綴
多列索引在滿足最左前綴時(shí)會(huì)被使用:col_name1, col_name2, col_name3;col_name1, col_name2;col_name1。

到此這篇關(guān)于MySQL索引總結(jié)(Index Type)的文章就介紹到這了,更多相關(guān)MySQL Index Type內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 超出MySQL最大連接數(shù)問(wèn)題及解決

    超出MySQL最大連接數(shù)問(wèn)題及解決

    這篇文章主要介紹了超出MySQL最大連接數(shù)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • SQL替換字符串值的5種常用方法

    SQL替換字符串值的5種常用方法

    這篇文章主要給大家介紹了關(guān)于SQL替換字符串值的5種常用方法,常用SQL的朋友應(yīng)該知道,SQL中一般都會(huì)提供一些字符串處理函數(shù),需要的朋友可以參考下
    2023-08-08
  • MySQL分庫(kù)分表id主鍵處理方式

    MySQL分庫(kù)分表id主鍵處理方式

    文章主要討論了在分庫(kù)分表后如何生成全局唯一的ID,包括基于數(shù)據(jù)庫(kù)的實(shí)現(xiàn)方案、UUID、獲取系統(tǒng)當(dāng)前時(shí)間和Snowflake算法,并對(duì)其優(yōu)缺點(diǎn)和適用場(chǎng)景進(jìn)行了分析
    2025-02-02
  • 解析MySQL8.0新特性——事務(wù)性數(shù)據(jù)字典與原子DDL

    解析MySQL8.0新特性——事務(wù)性數(shù)據(jù)字典與原子DDL

    這篇文章主要介紹了MySQL8.0新特性——事務(wù)性數(shù)據(jù)字典與原子DDL的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)MySQL8.0感興趣的朋友可以了解下
    2020-08-08
  • Mysql中between...and引起的索引失效問(wèn)題及解決

    Mysql中between...and引起的索引失效問(wèn)題及解決

    這篇文章主要介紹了Mysql中between...and引起的索引失效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • mysql8.0.21下載安裝詳細(xì)教程

    mysql8.0.21下載安裝詳細(xì)教程

    這篇文章主要介紹了mysql8.0.21下載安裝詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • MySQL數(shù)據(jù)庫(kù)如何開(kāi)啟遠(yuǎn)程連接(多備份)

    MySQL數(shù)據(jù)庫(kù)如何開(kāi)啟遠(yuǎn)程連接(多備份)

    多備份服務(wù)器在備份你的數(shù)據(jù)庫(kù)時(shí),必須能夠遠(yuǎn)程連接上你的數(shù)據(jù)庫(kù)。但是一般來(lái)說(shuō)mysql安裝時(shí)都是關(guān)閉遠(yuǎn)程連接的,因此,需要你開(kāi)通mysql數(shù)據(jù)庫(kù)的遠(yuǎn)程訪問(wèn)權(quán)限。那么如何開(kāi)啟呢
    2015-01-01
  • mysql主從同步快速設(shè)置方法

    mysql主從同步快速設(shè)置方法

    記錄一個(gè)比較簡(jiǎn)便的mysql的主從同步設(shè)置步驟,方便日后使用。
    2010-12-12
  • MySQL單表查詢操作實(shí)例詳解【語(yǔ)法、約束、分組、聚合、過(guò)濾、排序等】

    MySQL單表查詢操作實(shí)例詳解【語(yǔ)法、約束、分組、聚合、過(guò)濾、排序等】

    這篇文章主要介紹了MySQL單表查詢操作,結(jié)合實(shí)例形式詳細(xì)分析了mysql單表查詢的語(yǔ)法、約束、分組、聚合、過(guò)濾、排序等相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2019-12-12
  • mysql高級(jí)學(xué)習(xí)之索引的優(yōu)劣勢(shì)及規(guī)則使用

    mysql高級(jí)學(xué)習(xí)之索引的優(yōu)劣勢(shì)及規(guī)則使用

    這篇文章主要給大家介紹了關(guān)于mysql高級(jí)學(xué)習(xí)之索引的優(yōu)劣勢(shì)及規(guī)則使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評(píng)論