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

聊聊MySQL中的存儲引擎

 更新時間:2020年08月30日 09:08:42   作者:云崖先生  
MySQL是當(dāng)前流行的數(shù)據(jù)庫引擎之一,具有成本低、速度快、體積小且開放源代碼的優(yōu)點(diǎn)。這篇文章主要介紹了MySQL中存儲引擎的相關(guān)知識,幫助大家更好的理解和學(xué)習(xí)數(shù)據(jù)庫技術(shù),感興趣的朋友可以了解下

基礎(chǔ)知識

   在關(guān)系型數(shù)據(jù)庫中每一個數(shù)據(jù)表相當(dāng)于一個文件,而不同的存儲引擎則會構(gòu)建出不同的表類型。

   存儲引擎的作用是規(guī)定數(shù)據(jù)表如何存儲數(shù)據(jù),如何為存儲的數(shù)據(jù)建立索引以及如何支持更新、查詢等技術(shù)的實現(xiàn)。

   在Oracle以及SqlServer等數(shù)據(jù)庫中只支持一種存儲引擎,故其數(shù)據(jù)存儲管理機(jī)制都是一樣的,而MySQL中提供了多種存儲引擎,用戶可以根據(jù)不同的需求為數(shù)據(jù)表選擇不同的存儲引擎,用戶也可以根據(jù)自己的需要編寫自己的存儲引擎。

   如處理文本文件可使用txt類型,處理圖片可使用png類型

存儲引擎

   在MySQL中支持多種存儲引擎,使用show engines;命令可查看所支持的存儲引擎

mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine       | Support | Comment                            | Transactions | XA  | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB       | DEFAULT | Supports transactions, row-level locking, and foreign keys   | YES     | YES | YES    |
| MRG_MYISAM     | YES   | Collection of identical MyISAM tables             | NO      | NO  | NO     |
| MEMORY       | YES   | Hash based, stored in memory, useful for temporary tables   | NO      | NO  | NO     |
| BLACKHOLE     | YES   | /dev/null storage engine (anything you write to it disappears) | NO      | NO  | NO     |
| MyISAM       | YES   | MyISAM storage engine                     | NO      | NO  | NO     |
| CSV        | YES   | CSV storage engine                       | NO      | NO  | NO     |
| ARCHIVE      | YES   | Archive storage engine                     | NO      | NO  | NO     |
| PERFORMANCE_SCHEMA | YES   | Performance Schema                       | NO      | NO  | NO     |
| FEDERATED     | NO   | Federated MySQL storage engine                 | NULL     | NULL | NULL    |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.00 sec)

mysql>

InnoDB

   InnoDB存儲引擎是MySQL默認(rèn)的存儲引擎,支持事務(wù)操作,其設(shè)計目標(biāo)主要面向聯(lián)機(jī)事務(wù)處理(OLTP)的應(yīng)用。

   特點(diǎn)是行鎖設(shè)計、支持外鍵,并支持類似Oracle的非鎖定讀,即默認(rèn)讀取操作不會產(chǎn)生鎖。 InnoDB存儲引擎將數(shù)據(jù)放在一個邏輯的表空間中,這個表空間就像黑盒一樣由InnoDB存儲引擎自身來管理。

   從MySQL4.1(包括 4.1)版本開始,可以將每個InnoDB存儲引擎的 表單獨(dú)存放到一個獨(dú)立的 ibd文件中。此外,InnoDB存儲引擎支持將裸設(shè)備(row disk)用 于建立其表空間。 InnoDB通過使用多版本并發(fā)控制(MVCC)來獲得高并發(fā)性,并且實現(xiàn)了SQL標(biāo)準(zhǔn) 的4種隔離級別,默認(rèn)為REPEATABLE級別,同時使用一種稱為netx-key locking的策略來避免幻讀(phantom)現(xiàn)象的產(chǎn)生。

   除此之外,InnoDB存儲引擎還提供了插入緩沖(insert buffer)、二次寫(double write)、自適應(yīng)哈希索引(adaptive hash index)、預(yù)讀(read ahead) 等高性能和高可用的功能。 對于表中數(shù)據(jù)的存儲,InnoDB存儲引擎采用了聚集(clustered)的方式,每張表都是按主鍵的順序進(jìn)行存儲的,如果沒有顯式地在表定義時指定主鍵,InnoDB存儲引擎會為每一 行生成一個 6字節(jié)的行ID(ROWID),并以此作為主鍵。 InnoDB存儲引擎是 MySQL數(shù)據(jù)庫最為常用的一種引擎,F(xiàn)acebook、Google、Yahoo等 公司的成功應(yīng)用已經(jīng)證明了 InnoDB存儲引擎具備高可用性、高性能以及高可擴(kuò)展性。對其底層實現(xiàn)的掌握和理解也需要時間和技術(shù)的積累。

   如果想深入了解 InnoDB存儲引擎的工作原理、實現(xiàn)和應(yīng)用可以參考《MySQL 技術(shù)內(nèi)幕:InnoDB存儲引擎》一書。

MyISAM

   不支持事務(wù)、表鎖設(shè)計、支持全文索引,主要面向一些 OLAP數(shù)據(jù)庫應(yīng)用,在MySQL5.5.8版本之前是默認(rèn)的存儲引擎(除 Windows 版本外)。數(shù)據(jù)庫系統(tǒng)與文件系統(tǒng)一個很大的不同在于對事務(wù)的支持,MyISAM存儲引擎是不支持事務(wù)的。

   究其根本,這也并不難理解。用戶在所有的應(yīng)用中是否都需要事務(wù)呢?在數(shù)據(jù)倉庫中,如果沒有ETL這些操作,只是簡單地通過報表查詢還需要事務(wù)的支持嗎?此外,MyISAM存儲引擎的另一個與眾不同的地方是,它的緩沖池只緩存(cache)索引文件,而不緩存數(shù)據(jù)文件,這與大多數(shù)的數(shù)據(jù)庫都不相同。

NDB

   2003年,MysqlAB公司從SonyEricsson公司收購了NDB存儲引擎。

   NDB存儲引擎是一個集群存儲引擎,類似于Oracle的RAC集群,不過與Oracle RAC的share everythin結(jié)構(gòu)不同的是,其結(jié)構(gòu)是share nothing的集群架構(gòu),因此能提供更高級別的高可用性。

   NDB存儲引擎的特點(diǎn)是數(shù)據(jù)全部放在內(nèi)存中(從 5.1 版本開始,可以將非索引數(shù)據(jù)放在磁盤上),因此主鍵查找(primary key lookups)的速度極快,并且能夠在線添加 NDB數(shù)據(jù)存儲節(jié)點(diǎn)(data node)以便線性地提高數(shù)據(jù)庫性能。

   由此可見,NDB存儲引擎是高可用、 高性能、高可擴(kuò)展性的數(shù)據(jù)庫集群系統(tǒng),其面向的也是OLTP的數(shù)據(jù)庫應(yīng)用類型。

Memory

   正如其名,Memory存儲引擎中的數(shù)據(jù)都存放在內(nèi)存中。

   數(shù)據(jù)庫重啟或發(fā)生崩潰,表中的數(shù)據(jù)都將消失。它非常適合于存儲OLTP數(shù)據(jù)庫應(yīng)用中臨時數(shù)據(jù)的臨時表,也可以作為OLAP數(shù)據(jù)庫應(yīng)用中數(shù)據(jù)倉庫的維度表。

   Memory存儲引擎默認(rèn)使用哈希索引,而不是通常熟悉的B+樹索引。

Infobright

  第三方的存儲引擎。

   其特點(diǎn)是存儲是按照列而非行的,因此非常適合OLAP的數(shù)據(jù)庫應(yīng)用。

   其官方網(wǎng)站是 http://www.infobright.org/,上面有不少成功的數(shù)據(jù) 倉庫案例可供分析。

NTSE

   網(wǎng)易公司開發(fā)的面向其內(nèi)部使用的存儲引擎。

   目前的版本不支持事務(wù),但提供壓縮、行級緩存等特性,不久的將來會實現(xiàn)面向內(nèi)存的事務(wù)支持。

BLACKHOLE

   洞存儲引擎,可以應(yīng)用于主備復(fù)制中的分發(fā)主庫。

配置引擎

建表指定

   在建表語句后使用engine關(guān)鍵字可指定存儲引擎。

   create table 表名(id int,name char) engine=存儲引擎(默認(rèn)innodb);

   以下將創(chuàng)建一個temp臨時表,使用memory存儲引擎。

mysql> create table temp(id int) engine=memory;
Query OK, 0 rows affected (0.01 sec)

mysql> show create table temp; # 查看創(chuàng)建信息
+-------+------------------------------------------------------------------------------------------+
| Table | Create Table                                       |
+-------+------------------------------------------------------------------------------------------+
| temp | CREATE TABLE `temp` (
 `id` int(11) DEFAULT NULL
) ENGINE=MEMORY DEFAULT CHARSET=latin1 |
+-------+------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql>

   memory中的數(shù)據(jù)將在關(guān)閉MySQL服務(wù)時清空。

   而blackhole存儲引擎特征則是無論插入多少條記錄表內(nèi)永遠(yuǎn)都不會存放。

配置指定

   在配置文件中,也可指定建表時的存儲引擎。

[mysqld]
#創(chuàng)建新表時將使用的默認(rèn)存儲引擎
default-storage-engine=INNODB

文件結(jié)構(gòu)

   這里以InnoDB為例,我們先創(chuàng)建出一個student表,再查看其文件結(jié)構(gòu)。

mysql> create table student(id int) engine=innodb;
Query OK, 0 rows affected (0.02 sec)

   student.frm 存儲的是表結(jié)構(gòu),如字段等信息

   student.ibd 存儲的是表數(shù)據(jù),如記錄等信息

以上就是聊聊MySQL中的存儲引擎的詳細(xì)內(nèi)容,更多關(guān)于MySQL 存儲引擎的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Mysql中tinyint與int的區(qū)別

    詳解Mysql中tinyint與int的區(qū)別

    本文詳細(xì)講解了Mysql中tinyint與int的區(qū)別,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12
  • 詳解MySQL中EXPLAIN解釋命令及用法講解

    詳解MySQL中EXPLAIN解釋命令及用法講解

    explain顯示了mysql如何使用索引來處理select語句以及連接表。可以幫助選擇更好的索引和寫出更優(yōu)化的查詢語句
    2017-11-11
  • MySQL六種約束的示例詳解(全網(wǎng)最全)

    MySQL六種約束的示例詳解(全網(wǎng)最全)

    約束是作用于表中字段上的規(guī)則,用于限制存儲在表中的數(shù)據(jù)。這篇文章主要為大家整理了一下MySQL中六種約束的用法,感興趣的可以了解一下
    2022-07-07
  • MySQL修改表結(jié)構(gòu)操作命令總結(jié)

    MySQL修改表結(jié)構(gòu)操作命令總結(jié)

    這篇文章主要介紹了MySQL修改表結(jié)構(gòu)操作命令總結(jié),包含如刪除列、添加列、修改列、添加主鍵、刪除主鍵、添加唯一索引、添加普通索引等內(nèi)容,需要的朋友可以參考下
    2014-12-12
  • 關(guān)于Mysql子查詢的三個應(yīng)用場景

    關(guān)于Mysql子查詢的三個應(yīng)用場景

    這篇文章主要介紹了關(guān)于Mysql子查詢的三個應(yīng)用場景,子查詢是在一個完整的查詢語句中,嵌套不同功能的小查詢,從而完成復(fù)雜查詢的一種編寫形式,需要的朋友可以參考下
    2023-07-07
  • MySQL緩存優(yōu)化方案總結(jié)

    MySQL緩存優(yōu)化方案總結(jié)

    最近迭代的產(chǎn)品版本從2.X來到了3.X,屬于一個非常大的產(chǎn)品升級,比上個版本多了很多功能,那么上線之前肯定要在一個干凈的環(huán)境里進(jìn)行測試回歸以及性能測試,本文總結(jié)一下數(shù)據(jù)庫層面的一些緩存機(jī)制對查詢速度整體的優(yōu)化,需要的朋友可以參考下
    2023-08-08
  • 解讀MySQL為什么不推薦使用外鍵

    解讀MySQL為什么不推薦使用外鍵

    這篇文章主要介紹了解讀MySQL為什么不推薦使用外鍵問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 解析MySQL創(chuàng)建外鍵關(guān)聯(lián)錯誤 - errno:150

    解析MySQL創(chuàng)建外鍵關(guān)聯(lián)錯誤 - errno:150

    本篇文章是對MySQL創(chuàng)建外鍵關(guān)聯(lián)錯誤-errno:150進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL 參數(shù)相關(guān)概念及查詢更改方法

    MySQL 參數(shù)相關(guān)概念及查詢更改方法

    這篇文章主要介紹了MySQL 參數(shù)相關(guān)概念及查詢更改方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-09-09
  • MySQL數(shù)據(jù)庫事務(wù)transaction示例講解教程

    MySQL數(shù)據(jù)庫事務(wù)transaction示例講解教程

    這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫事務(wù)transaction的示例講解教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10

最新評論