1.儲存引擎介紹
資料庫中的表也應該有不同的型別,表的型別不同,會對應mysql不同的存取機制,表型別又稱為儲存引擎。
ps: 儲存引擎說白了就是如何儲存資料、如何為儲存的資料建立索引和如何更新、查詢資料等技術的實現方法。因為在關聯式資料庫中資料的儲存是以表的形式儲存的,所以儲存引擎也可以稱為表型別(即儲存和操作此表的型別)
在Oracle 和SQL Server等資料庫中只有一種儲存引擎,所有資料儲存管理機制都是一樣的。而MySql
資料庫提供了多種儲存引擎。使用者可以根據不同的需求為資料表選擇不同的儲存引擎,使用者也可以根據
自己的需要編寫自己的儲存引擎
SQL 解析器、SQL 優化器、緩衝池、儲存引擎等元件在每個資料庫中都存在,但不是每 個資料庫都有這麼多儲存引擎。MySQL 的外掛式儲存引擎可以讓儲存引擎層的開發人員設 計他們希望的儲存層,例如,有的應用需要滿足事務的要求,有的應用則不需要對事務有這 麼強的要求 ;有的希望資料能持久儲存,有的只希望放在記憶體中,臨時並快速地提供對資料 的查詢。
2.mysql支援的儲存引擎
mysql> show engines\G;# 檢視所有支援的引擎 mysql> show variables like 'storage_engine%'; # 檢視正在使用的儲存引擎
1、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 儲存引擎》一書。
2、MyISAM 儲存引擎
不支援事務、表鎖設計、支援全文索引,主要面向一些 OLAP 數 據庫應用,在 MySQL 5.5.8 版本之前是預設的儲存引擎(除 Windows 版本外)。資料庫系統 與檔案系統一個很大的不同在於對事務的支援,MyISAM 儲存引擎是不支援事務的。究其根 本,這也並不難理解。使用者在所有的應用中是否都需要事務呢?在資料倉儲中,如果沒有 ETL 這些操作,只是簡單地通過報表查詢還需要事務的支援嗎?此外,MyISAM 儲存引擎的 另一個與眾不同的地方是,它的緩衝池只快取(cache)索引檔案,而不快取資料檔案,這與 大多數的資料庫都不相同。
3、NDB 儲存引擎
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 的資料庫應用型別。
4、Memory 儲存引擎
正如其名,Memory 儲存引擎中的資料都存放在記憶體中,資料庫重 啟或發生崩潰,表中的資料都將消失。它非常適合於儲存 OLTP 資料庫應用中臨時資料的臨時表,也可以作為 OLAP 資料庫應用中資料倉儲的維度表。Memory 儲存引擎預設使用雜湊 索引,而不是通常熟悉的 B+ 樹索引
5、Infobright 儲存引擎
第三方的儲存引擎。其特點是儲存是按照列而非行的,因此非常 適合 OLAP 的資料庫應用。其官方網站是 http://www.infobright.org/,上面有不少成功的資料 倉庫案例可供分析
6、NTSE 儲存引擎
網易公司開發的面向其內部使用的儲存引擎。目前的版本不支援事務, 但提供壓縮、行級快取等特性,不久的將來會實現面向記憶體的事務支援。
7、BLACKHOLE
黑洞儲存引擎,可以應用於主備複製中的分發主庫。
MySQL 資料庫還有很多其他儲存引擎,上述只是列舉了最為常用的一些引擎。如果 你喜歡,完全可以編寫專屬於自己的引擎,這就是開源賦予我們的能力,也是開源的魅 力所在。
create table t1(id int)engine=innodb;# 預設不寫就是innodb
建立四張表,分別使用innodb,myisam,memory,blackhole儲存引擎,進行插入資料測試
create table t1(id int)engine=innodb; create table t2(id int)engine=myisam; create table t3(id int)engine=memory; create table t4(id int)engine=blackhole;
#.frm是儲存資料表的框架結構
# .ibd是mysql資料檔案
#.MYD是MyISAM表的資料檔案的副檔名
#.MYI是MyISAM表的索引的副檔名
#發現後兩種儲存引擎只有表結構,無資料
#memory,在重啟mysql或者重啟機器後,表內資料清空
#blackhole,往表內插入任何資料,都相當於丟入黑洞,表內永遠不存記錄
3.表介紹
表相當於檔案,表中的一條記錄相當於檔案中的一行內容,不同的是,表中的一條記錄有對應的標題,稱為欄位。
4.建立表
create table 表名( 欄位名1 型別[(寬度) 約束條件], 欄位名2 型別[(寬度) 約束條件], 欄位名3 型別[(寬度) 約束條件] ); #注意: 1. 在同一張表中,欄位名是不能相同 2. 寬度和約束條件可選 3. 欄位名和型別是必須的
1.建立資料庫
create database db1;
2.使用資料庫
use db1;
3.建立a1表
create table a1(
id int,
name varchar(20),
age int(3)
);
4.插入表的記錄
insert into a1 values(1,'mmm','18'),(2,'sss','18');
5.查詢表的資料和結構
(1)查詢a1表中的資料
select * from a1;
(2)查詢a1表的結構
desc a1;
(3)檢視錶的詳細結構
show create table a1\G;
6.複製表
(1)新建立一個資料庫db3
create database db3;
(2)使用db3
use db3;
(3)複製db1.a1的表格結構和記錄
create table a1 select * from bd1.a1;
(4)檢視db3.a1中的資料結構進和表結構
mysql> select*from db3.a1; +------+------+------+ | id | name | age | +------+------+------+ | 1 | wqz | 18 | | 2 | www | 18 | +------+------+------+ 2 rows in set (0.00 sec)
ps1:如果只要表結構,不要記錄
在db1資料庫目錄下建立一個b2表,給一個where條件,條件要求不成立,只拷貝結構
mysql> create table b2 select *from db3.a1 where 1>2;
Query OK, 0 rows affected (0.65 sec)
Records: 0 Duplicates: 0 Warnings: 0
檢視錶結構
mysql> desc b2; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | id | int(11) | YES | | NULL | | | name | varchar(10) | YES | | NULL | | | age | int(3) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 3 rows in set (0.00 sec)
ps2:使用like(只copy 表的結構,不copy記錄)
mysql> create table b3 like db3.a1; Query OK, 0 rows affected (0.23 sec) mysql> select * from b3; Empty set (0.00 sec)
7.刪除表
drop table 表名