標籤:out str 開始 需求 特性 googl 練習 int 特點
閱讀目錄
- 一 什麼是儲存引擎
- 二 mysql支援的儲存引擎
- 三 使用儲存引擎
一 什麼是儲存引擎
mysql中建立的庫===>檔案夾
庫中建立的表===>檔案
現實生活中我們用來儲存資料的檔案有不同的類型,每種檔案類型對應各自不同的處理機制:比如處理文本用txt類型,處理表格用excel,處理圖片用png等
資料庫中的表也應該有不同的類型,表的類型不同,會對應mysql不同的存取機制,表類型又稱為儲存引擎。
儲存引擎說白了就是如何儲存資料、如何為儲存的資料建立索引和如何更新、查詢資料等技術的實現方
法。因為在關聯式資料庫中資料的儲存是以表的形式儲存的,所以儲存引擎也可以稱為表類型(即儲存和
操作此表的類型)
在Oracle 和SQL Server等資料庫中只有一種儲存引擎,所有資料存放區管理機制都是一樣的。而MySql
資料庫提供了多種儲存引擎。使用者可以根據不同的需求為資料表選擇不同的儲存引擎,使用者也可以根據
自己的需要編寫自己的儲存引擎
SQL 解析器、SQL 最佳化器、緩衝池、儲存引擎等組件在每個資料庫中都存在,但不是每 個資料庫都有這麼多儲存引擎。MySQL 的外掛程式式儲存引擎可以讓儲存引擎層的開發人員設 計他們希望的儲存層,例如,有的應用需要滿足事務的要求,有的應用則不需要對事務有這 麼強的要求 ;有的希望資料能持久儲存,有的只希望放在記憶體中,臨時並快速地提供對資料 的查詢。
二 mysql支援的儲存引擎
MariaDB [(none)]> show engines\G #查看所有支援的儲存引擎MariaDB [(none)]> show variables like ‘storage_engine%‘; #查看正在使用的儲存引擎
MySQL儲存引擎介紹
#InnoDB 儲存引擎支援事務,其設計目標主要面向聯機交易處理(OLTP)的應用。其特點是行鎖設計、支援外鍵,並支援類似 Oracle 的非鎖定讀,即預設讀取操作不會產生鎖。 從 MySQL 5.5.8 版本開始是預設的儲存引擎。InnoDB 儲存引擎將資料放在一個邏輯的資料表空間中,這個資料表空間就像黑盒一樣由 InnoDB 儲存引擎自身來管理。從 MySQL 4.1(包括 4.1)版本開始,可以將每個 InnoDB 儲存引擎的 表單獨存放到一個獨立的 ibd 檔案中。此外,InnoDB 儲存引擎支援將裸裝置(row disk)用 於建立其資料表空間。InnoDB 通過使用多版本並發控制(MVCC)來獲得高並發性,並且實現了 SQL 標準 的 4 種隔離等級,預設為 REPEATABLE 層級,同時使用一種稱為 netx-key locking 的策略來 避免幻讀(phantom)現象的產生。除此之外,InnoDB 儲存引擎還提供了插入緩衝(insert buffer)、二次寫(double write)、自適應雜湊索引(adaptive hash index)、預讀(read ahead) 等高效能和高可用的功能。對於表中資料的儲存,InnoDB 儲存引擎採用了聚集(clustered)的方式,每張表都是按 主鍵的順序進行儲存的,如果沒有顯式地在表定義時指定主鍵,InnoDB 儲存引擎會為每一 行產生一個 6 位元組的 ROWID,並以此作為主鍵。InnoDB 儲存引擎是 MySQL 資料庫最為常用的一種引擎,Facebook、Google、Yahoo 等 公司的成功應用已經證明了 InnoDB 儲存引擎具備高可用性、高效能以及高可擴充性。對其 底層實現的掌握和理解也需要時間和技術的積累。如果想深入瞭解 InnoDB 儲存引擎的工作 原理、實現和應用,可以參考《MySQL 技術內幕:InnoDB 儲存引擎》一書。#MyISAM 儲存引擎不支援事務、表鎖設計、支援全文索引,主要面向一些 OLAP 數 據庫應用,在 MySQL 5.5.8 版本之前是預設的儲存引擎(除 Windows 版本外)。資料庫系統 與檔案系統一個很大的不同在於對事務的支援,MyISAM 儲存引擎是不支援事務的。究其根 本,這也並不難理解。使用者在所有的應用中是否都需要事務呢?在資料倉儲中,如果沒有 ETL 這些操作,只是簡單地通過報表查詢還需要事務的支援嗎?此外,MyISAM 儲存引擎的 另一個與眾不同的地方是,它的緩衝池只緩衝(cache)索引檔案,而不快取資料檔案,這與 大多數的資料庫都不相同。#NDB 儲存引擎2003 年,MySQL AB 公司從 Sony Ericsson 公司收購了 NDB 儲存引擎。 NDB 儲存引擎是一個叢集儲存引擎,類似於 Oracle 的 RAC 叢集,不過與 Oracle RAC 的 share everything 結構不同的是,其結構是 share nothing 的叢集架構,因此能提供更進階別的 高可用性。NDB 儲存引擎的特點是資料全部放在記憶體中(從 5.1 版本開始,可以將非索引數 據放在磁碟上),因此主鍵尋找(primary key lookups)的速度極快,並且能夠線上添加 NDB 資料存放區節點(data node)以便線性地提高資料庫效能。由此可見,NDB 儲存引擎是高可用、 高效能、高可擴充性的資料庫叢集系統,其面向的也是 OLTP 的資料庫應用類型。#Memory 儲存引擎正如其名,Memory 儲存引擎中的資料都存放在記憶體中,資料庫重 啟或發生崩潰,表中的資料都將消失。它非常適合於儲存 OLTP 資料庫應用中臨時資料的暫存資料表,也可以作為 OLAP 資料庫應用中資料倉儲的維度資料表。Memory 儲存引擎預設使用雜湊 索引,而不是通常熟悉的 B+ 樹索引。#Infobright 儲存引擎第三方的儲存引擎。其特點是儲存是按照列而非行的,因此非常 適合 OLAP 的資料庫應用。其官方網站是 http://www.infobright.org/,上面有不少成功的資料 倉庫案例可供分析。#NTSE 儲存引擎網易公司開發的面向其內部使用的儲存引擎。目前的版本不支援事務, 但提供壓縮、行級緩衝等特性,不久的將來會實現面向記憶體的事務支援。#BLACKHOLE黑洞儲存引擎,可以應用於主備複製中的分發主庫。MySQL 資料庫還有很多其他儲存引擎,上述只是列舉了最為常用的一些引擎。如果 你喜歡,完全可以編寫專屬於自己的引擎,這就是開源賦予我們的能力,也是開源的魅 力所在。
View Code 三 使用儲存引擎
方法1:建表時指定
MariaDB [db1]> create table innodb_t1(id int,name char)engine=innodb;MariaDB [db1]> create table innodb_t2(id int)engine=innodb;MariaDB [db1]> show create table innodb_t1;MariaDB [db1]> show create table innodb_t2;
方法2:在設定檔中指定預設的儲存引擎
/etc/my.cnf[mysqld]default-storage-engine=INNODBinnodb_file_per_table=1
查看
[[email protected] db1]# cd /var/lib/mysql/db1/[[email protected] db1]# lsdb.opt innodb_t1.frm innodb_t1.ibd innodb_t2.frm innodb_t2.ibd
練習
建立四個表,分別使用innodb,myisam,memory,blackhole儲存引擎,進行插入資料測試
MariaDB [db1]> create table t1(id int)engine=innodb;MariaDB [db1]> create table t2(id int)engine=myisam;MariaDB [db1]> create table t3(id int)engine=memory;MariaDB [db1]> create table t4(id int)engine=blackhole;MariaDB [db1]> quit[[email protected] db1]# ls /var/lib/mysql/db1/ #發現後兩種儲存引擎只有表結構,無資料db.opt t1.frm t1.ibd t2.MYD t2.MYI t2.frm t3.frm t4.frm#memory,在重啟mysql或者重啟機器後,表內資料清空#blackhole,往表插入入任何資料,都相當於丟入黑洞,表內永遠不存記錄
mysql三-1:儲存引擎