久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

聊聊MySQL中的存儲引擎

瀏覽:65日期:2023-10-12 11:48:27

基礎知識

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

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

在Oracle以及SqlServer等數(shù)據(jù)庫中只支持一種存儲引擎,故其數(shù)據(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默認的存儲引擎,支持事務操作,其設計目標主要面向聯(lián)機事務處理(OLTP)的應用。

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

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

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

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

MyISAM

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

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

NDB

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

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

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

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

Memory

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

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

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

Infobright

第三方的存儲引擎。

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

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

NTSE

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

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

BLACKHOLE

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

配置引擎

建表指定

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

create table 表名(id int,name char) engine=存儲引擎(默認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ù)將在關閉MySQL服務時清空。

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

配置指定

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

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

文件結構

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

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

聊聊MySQL中的存儲引擎

student.frm 存儲的是表結構,如字段等信息

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

以上就是聊聊MySQL中的存儲引擎的詳細內容,更多關于MySQL 存儲引擎的資料請關注好吧啦網(wǎng)其它相關文章!

相關文章:
主站蜘蛛池模板: 连云港市| 宽甸| 四会市| 鹤庆县| 兴和县| 黔西| 墨玉县| 永福县| 莆田市| 庆元县| 大英县| 阜南县| 大厂| 平罗县| 拜泉县| 乌鲁木齐市| 香港| 凤翔县| 岑溪市| 开阳县| 富源县| 罗源县| 黄浦区| 巴东县| 莱芜市| 泸西县| 榆社县| 夏津县| 驻马店市| 峨眉山市| 元朗区| 清新县| 鹤庆县| 南丰县| 大丰市| 麻阳| 星子县| 姜堰市| 晴隆县| 宝清县| 敦煌市|