溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

什么是MySQL的索引、事務(wù)及存儲(chǔ)引擎

發(fā)布時(shí)間:2020-04-25 11:52:23 來源:億速云 閱讀:288 作者:三月 欄目:系統(tǒng)運(yùn)維

本文主要給大家介紹什么是MySQL的索引、事務(wù)及存儲(chǔ)引擎,希望可以給大家補(bǔ)充和更新些知識(shí),如有其它問題需要了解的可以持續(xù)在億速云行業(yè)資訊里面關(guān)注我的更新文章的。

一、索引

概念
在一本書中,無須閱讀整本書,利用目錄就可以快速查找所需信息;
書中的目錄是一個(gè)詞語列表,其中注明了包含各個(gè)詞的頁碼

數(shù)據(jù)庫索引
在數(shù)據(jù)庫中,索引數(shù)據(jù)庫程序無須對(duì)整個(gè)表進(jìn)行掃描,就可以在其中找到所需數(shù)據(jù);
數(shù)據(jù)庫中的索引是某個(gè)表中一列或者若干列值的集合,以及物理標(biāo)識(shí)這些值的數(shù)據(jù)頁的邏輯指針清單

索引的作用
1、設(shè)置了合適的索引之后,數(shù)據(jù)庫利用各種快速的定位技術(shù),能夠大大加快查詢速率;
2、特別是當(dāng)表很大時(shí),或者查詢涉及到多個(gè)表時(shí),使用索引可使查詢加快成千倍;
3、可以降低數(shù)據(jù)庫的IO成本,并且索引還可以降低數(shù)據(jù)庫的排序成本;
4、通過創(chuàng)建唯一性索引保證數(shù)據(jù)表數(shù)據(jù)的唯一性;
5、可以加快表與表之間的連接;
6、在使用分組和排序時(shí),可大大減少分組和排序時(shí)間。
索引的分類

什么是MySQL的索引、事務(wù)及存儲(chǔ)引擎

普通索引:這是最基本的索引類型,而且它沒有唯一性之類的限制
唯一性索引:這種索引和前面的"普通索引"基本相同,但有一個(gè)區(qū)別:索引列的所有值都只能出現(xiàn)一次,即必須唯一
主鍵索引:主鍵是一種唯一性索引,但它必須制定為"PRIMARY KEY"
全文索引:全文索引的類型是FULLTEXT,可以在VARCHAR或者TEXT類型的列上創(chuàng)建
單列索引與多列索引:索引可以是單列上創(chuàng)建的索引,也可以是在多列上創(chuàng)建的索引

創(chuàng)建索引的原則依據(jù)

表的主鍵,外鍵必須有索引;
數(shù)據(jù)量超過300行的表應(yīng)該有索引;
經(jīng)常與其他表進(jìn)行連接的表,在連接字段上應(yīng)該建立索引;
唯一性太差的字段不適合建立索引;
更新太頻繁的字段不適合創(chuàng)建索引;
經(jīng)常出現(xiàn)在where子句中的字段,特別是大表的字段,應(yīng)該建立索引;
索引應(yīng)該建在選擇性高的字段上;
索引應(yīng)該建在小字段上,對(duì)于大的文本字段甚至超長字段,不要建索引;

創(chuàng)建索引的方法

根據(jù)企業(yè)需求選擇了合適的索引之后,可使用CREATE INDEX創(chuàng)建索引
CREATE INDEX加上各個(gè)索引關(guān)鍵字便可創(chuàng)建各個(gè)類型的索引

創(chuàng)建普通索引

CREATE INDEX <索引的名字> ON tablename (列的列表);
CREATE INDEX salary_index ON IT_salary(薪資);

創(chuàng)建唯一性索引

CREATE UNIQUE INDEX <索引的名字> ON tablename (列的列表);
CREATE UNIQUE INDEX salary_unique_index ON IT_salary(姓名);

創(chuàng)建主鍵索引

CREATE TABLE tablename ( [...],PRIMARY KEY (列的列表));
ALTER TABLE tablename ADD PRIMARY KEY (列的列表);

例子:ALTER TABLE IT_salary ADD PRIMARY KEY (員工ID);

索引查看

SHOW INDEX FROM tablename;
SHOW KEYS FROM tablename;

例子:SHOW INDEX FROM IT_salary;
           SHOW KEYS FROM IT_salary;

二、事務(wù)

概念
?事務(wù)是一種機(jī)制,一個(gè)操作序列,包含了一組數(shù)據(jù)庫操作命令,并且把所有的命令作為一個(gè)整體一起向系統(tǒng)提交或撤銷操作請(qǐng)求,即這一組數(shù)據(jù)庫命令要么都執(zhí)行,要么都不執(zhí)行;
?事務(wù)是一個(gè)不可分割的工作邏輯單元,在數(shù)據(jù)庫系統(tǒng)上執(zhí)行并發(fā)操作時(shí),事務(wù)是最小的控制單元;
?使用于多用戶同時(shí)操作的數(shù)據(jù)庫系統(tǒng)的場(chǎng)景,如銀行,保險(xiǎn)公司及證券交易系統(tǒng)等等;
?通過事務(wù)的整體性以保證數(shù)據(jù)的一致性;
特點(diǎn)

 1、原子性:事務(wù)是一個(gè)完整的操作,事務(wù)的各元素是不可分的(原子的)
    事務(wù)中的所有元素必須作為一個(gè)整體提交或回滾
    如果事務(wù)中的任何元素失敗,則整個(gè)事務(wù)將失敗

 2、一致性:當(dāng)事務(wù)完成時(shí),數(shù)據(jù)必須處于一致狀態(tài):在事務(wù)開始之前,數(shù)據(jù)庫中存儲(chǔ)的數(shù)據(jù)處于一致狀態(tài);在正在進(jìn)行的事務(wù)中,數(shù)據(jù)可能處于不一致的狀態(tài);當(dāng)事務(wù)成功完成時(shí),數(shù)據(jù)必須再次回到已知的一致狀態(tài)

 3、隔離性:對(duì)數(shù)據(jù)進(jìn)行修改的所有并發(fā)事務(wù)是彼此隔離的,這表明事務(wù)必須是獨(dú)立的,他不應(yīng)以任何方式依賴于或影響其他事務(wù)
    修改數(shù)據(jù)的事務(wù)可以在另一個(gè)使用相同數(shù)據(jù)的事務(wù)開始之前訪問這些數(shù)據(jù),或者再另一個(gè)使用相同的數(shù)據(jù)的事務(wù)結(jié)束之后訪問這些數(shù)據(jù)

 4、持久性:事務(wù)持久性指不管系統(tǒng)是否發(fā)生故障,事務(wù)處理的結(jié)果都是永久的
    一旦事務(wù)被提交,事務(wù)的效果會(huì)被永久的保留在數(shù)據(jù)庫中

事務(wù)的操作
默認(rèn)情況下的MySQL的事務(wù)是自動(dòng)提交的,當(dāng)SQL語句提交時(shí)事務(wù)便自動(dòng)提交
手動(dòng)對(duì)事務(wù)進(jìn)行控制的方法:
1、事務(wù)處理命令控制
2、使用set設(shè)置事務(wù)出來方式
事務(wù)處理命令控制事務(wù):

begin:開始一個(gè)事務(wù)
commit:提交一個(gè)事務(wù)
rollback:回滾一個(gè)事務(wù)

使用set命令進(jìn)行控制:

set autocommit=0:禁止自動(dòng)提交
set autocommit=1:開啟自動(dòng)提交

三、存儲(chǔ)引擎

概念介紹

MySQL中的數(shù)據(jù)用各種不同的技術(shù)存儲(chǔ)在文件中,每一種技術(shù)都使用不同的存儲(chǔ)機(jī)制,索引技巧,鎖定水平并最終提供不同的功能和能力,這些不同的技術(shù)以及配套的功能在MySQL中稱為存儲(chǔ)引擎
    ?存儲(chǔ)引擎就是MySQL將數(shù)據(jù)存儲(chǔ)在文件系統(tǒng)中的存儲(chǔ)方式或存儲(chǔ)格式
    ?目前MySQL常用的兩種存儲(chǔ)引擎:
    ??MyISQM
    ??InnoDB
    ?MySQL存儲(chǔ)引擎是MySQL數(shù)據(jù)庫云服務(wù)器中的組件,負(fù)責(zé)為數(shù)據(jù)庫執(zhí)行實(shí)際的數(shù)據(jù)I/O操作
    ?使用特殊存儲(chǔ)引擎的主要優(yōu)點(diǎn)之一在于,僅需提供特殊應(yīng)用所需的特性,數(shù)據(jù)庫中的系統(tǒng)開銷較小,具有更有效和更高的數(shù)據(jù)庫性能
    ?MySQL系統(tǒng)中,存儲(chǔ)引擎處于文件系統(tǒng)之上,在數(shù)據(jù)保存到數(shù)據(jù)文件之前會(huì)傳輸存儲(chǔ)引擎,之后按照各個(gè)存儲(chǔ)引擎的存儲(chǔ)格式進(jìn)行存儲(chǔ)

什么是MySQL的索引、事務(wù)及存儲(chǔ)引擎

MyISQM的概述

ISAM的特點(diǎn):

ISAM執(zhí)行讀取操作的速度很快
而且不占用大量的內(nèi)存和存儲(chǔ)資源
他不支持事務(wù)處理
不能夠容錯(cuò)

MyISAM的特點(diǎn):

1、不支持事務(wù)
2、表級(jí)鎖定形式,數(shù)據(jù)在更新時(shí)鎖定整個(gè)表
3、數(shù)據(jù)庫在讀寫過程中相互阻塞
●會(huì)在數(shù)據(jù)寫入的過程阻塞用戶數(shù)據(jù)的讀取
●也會(huì)在數(shù)據(jù)讀取的過程中阻塞用戶的數(shù)據(jù)寫入
4、可通過key_buffer_size來設(shè)置緩存索引,提高訪問性能,減少磁盤IO的壓力
●但緩存只會(huì)緩存索引文件,不會(huì)緩存數(shù)據(jù)
5、采用MyISAM存儲(chǔ)引擎數(shù)據(jù)單獨(dú)寫入或讀取,速度過程較快且占用資源相對(duì)少
6、MyISAM存儲(chǔ)引擎它不支持外鍵約束,只支持全文索引
7、每個(gè)MyISAM在磁盤.上存儲(chǔ)成三個(gè)文件,每- -個(gè)文件的名字以表的名字開始,擴(kuò)展名指出文件類型
8、MyISAM在磁盤.上存儲(chǔ)的文件
●.frm文件存儲(chǔ)表定義
●數(shù)據(jù)文件的擴(kuò)展名為.MYD (MYData)
●索引文件的擴(kuò)展名是.MYI (MYIndex)

MyISAM適用的生產(chǎn)場(chǎng)景

公司業(yè)務(wù)不需要事務(wù)的支持
一般單方面讀取數(shù)據(jù)比較多的業(yè)務(wù),或單方面寫入數(shù)據(jù)比較多的業(yè)務(wù)
MyISAM存儲(chǔ)引擎數(shù)據(jù)讀寫都比較頻繁場(chǎng)景不適合
使用讀寫并發(fā)訪問相對(duì)較低的業(yè)務(wù)
數(shù)據(jù)修改相對(duì)較少的業(yè)務(wù)
對(duì)數(shù)據(jù)業(yè)務(wù)一致性要求不是非常高的業(yè)務(wù)
服務(wù)器硬件資源相對(duì)比較差

InnoDB特點(diǎn)介紹

支持事務(wù):支持4個(gè)事務(wù)隔離級(jí)別
行級(jí)鎖定,但是全表掃描仍然會(huì)是表級(jí)鎖定
讀寫阻塞與事務(wù)隔離級(jí)別相關(guān)
具有非常高效的緩存特性:能緩存索引,也能緩存數(shù)據(jù)
表與主鍵以簇的方式存儲(chǔ)
支持分區(qū)、表空間,類似oracle數(shù)據(jù)庫
支持外鍵約束,5.5以前不支持全文索引,5.5版本以后支持全文索引
對(duì)硬件資源要求還是比較高的場(chǎng)合

InnoDB適用生產(chǎn)場(chǎng)景

業(yè)務(wù)需要事務(wù)的支持
行級(jí)鎖定對(duì)高并發(fā)有很好的適應(yīng)能力,但需確保查詢是通過索引來完成
業(yè)務(wù)數(shù)據(jù)更新較為頻繁的場(chǎng)景,如:論壇,微博等
業(yè)務(wù)數(shù)據(jù)一致性要求較高,例如:銀行業(yè)務(wù)
硬件設(shè)備內(nèi)存較大,利用Innodb較好的緩存能力來提高內(nèi)存利用率,減少磁盤I0的壓力

企業(yè)選擇存儲(chǔ)引擎依據(jù)

需要考慮每個(gè)存儲(chǔ)引擎提供了那些不同的核心功能及應(yīng)運(yùn)場(chǎng)景

支持的字段和數(shù)據(jù)類型

所有引擎都支持通用的數(shù)據(jù)類型
但不是所有的引擎都支持其他的字段類型,如二進(jìn)制對(duì)象

鎖定類型:不同的存儲(chǔ)引擎支持不同級(jí)別的鎖定

表鎖定
行鎖定

支持的索引

建立索引在搜索和恢復(fù)數(shù)據(jù)庫中的數(shù)據(jù)的時(shí)候能夠顯著提高性能
不同的存儲(chǔ)引擎提供不同的制作索引的技術(shù)
有些存儲(chǔ)引擎根本不支持索引

支持的事務(wù)處理

事務(wù)處理功能通過提供在向表中更新和插入信息期間的可靠性
課根據(jù)企業(yè)業(yè)務(wù)是否支持事務(wù)選項(xiàng)選擇存儲(chǔ)引擎

配置存儲(chǔ)引擎MyISA

在企業(yè)中選擇好合適的存儲(chǔ)引擎之后,就可以進(jìn)行修改了
修改步驟

查看數(shù)據(jù)庫可配置的存儲(chǔ)引擎
查看表正在使用的存儲(chǔ)引擎
配置存儲(chǔ)引擎為所選擇的類型

使用show engines查看系統(tǒng)支持的存儲(chǔ)引擎
方法1:     show table status from  庫名  where  name = '表名';
方法2:      show create table    表名;
修改存儲(chǔ)引擎

方法1: alter table修改;
           alter table table_ name engine=引擎;
方法2:修改my.cnf,指定默認(rèn)存儲(chǔ)引擎并重啟服務(wù)
          default-storage-engine=InnDB
方法3: create table創(chuàng)建表時(shí)指定存儲(chǔ)引擎
           create table   表名   (字段) engine=   引擎
方法4: Mysql_ convert_ table_ format 轉(zhuǎn)化存儲(chǔ)引擎
           Mysql_ convert_ table_ format -user=root -password=密碼

          - sock=/tmp/mysql.sock - engine =引擎 庫名 表名

看了以上關(guān)于什么是MySQL的索引、事務(wù)及存儲(chǔ)引擎,希望能給大家在實(shí)際運(yùn)用中帶來一定的幫助。本文由于篇幅有限,難免會(huì)有不足和需要補(bǔ)充的地方,如有需要更加專業(yè)的解答,可在官網(wǎng)聯(lián)系我們的24小時(shí)售前售后,隨時(shí)幫您解答問題的。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI