好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 聊聊MySQL中的存儲引擎

聊聊MySQL中的存儲引擎

熱門標簽:宜賓全自動外呼系統廠家 許昌外呼增值業務線路 石家莊400電話辦理公司 申請400電話電話價格 新鄉智能外呼系統好處 地圖標注客戶付款 廣東400企業電話申請流程 咸陽防封電銷卡 臨沂做地圖標注

基礎知識

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

   存儲引擎的作用是規定數據表如何存儲數據,如何為存儲的數據建立索引以及如何支持更新、查詢等技術的實現。

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

   如處理文本文件可使用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默認的存儲引擎,支持事務操作,其設計目標主要面向聯機事務處理(OLTP)的應用。

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

   從MySQL4.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字節的行ID(ROWID),并以此作為主鍵。 InnoDB存儲引擎是 MySQL數據庫最為常用的一種引擎,Facebook、Google、Yahoo等 公司的成功應用已經證明了 InnoDB存儲引擎具備高可用性、高性能以及高可擴展性。對其底層實現的掌握和理解也需要時間和技術的積累。

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

MyISAM

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

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

NDB

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

   NDB存儲引擎是一個集群存儲引擎,類似于Oracle的RAC集群,不過與Oracle RAC的share everythin結構不同的是,其結構是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

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

配置引擎

建表指定

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

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

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

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

mysql> show create table temp; # 查看創建信息
+-------+------------------------------------------------------------------------------------------+
| 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中的數據將在關閉MySQL服務時清空。

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

配置指定

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

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

文件結構

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

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

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

   student.ibd 存儲的是表數據,如記錄等信息

以上就是聊聊MySQL中的存儲引擎的詳細內容,更多關于MySQL 存儲引擎的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • SQL Server中的執行引擎入門 圖解
  • MySQL 常見存儲引擎的優劣
  • 修改MySQL數據庫引擎為InnoDB的操作
  • 關于MySQL Memory存儲引擎的相關知識
  • 詳解mysql中的存儲引擎
  • MySQL 選擇合適的存儲引擎
  • MySQL創建數據表時設定引擎MyISAM/InnoDB操作
  • 簡述MySQL InnoDB存儲引擎
  • 如何自己動手寫SQL執行引擎

標簽:阜新 鎮江 北京 貴州 臺灣 合肥 日照 鷹潭

巨人網絡通訊聲明:本文標題《聊聊MySQL中的存儲引擎》,本文關鍵詞  聊聊,MySQL,中的,存儲,引擎,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《聊聊MySQL中的存儲引擎》相關的同類信息!
  • 本頁收集關于聊聊MySQL中的存儲引擎的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 最新版资源在线天堂| 最新黄色片| 99久热国产精品视频尤物不卡| 无码人妻一区二区三区在线视频| 《性女游戏》女同电影| 国模国模琳琳大尺私拍图片| 91精品国产一区二区三区| 男人扎爽进女人j羞羞漫画| 欧美日韩亚洲一区二区| 边做边叫床的大尺度视频免费| rosi大尺度福利写真视频| 性色国产成人久久久精品一区二区| 欧美日韩Av无码精品久线| 黄色上床片| s对m每天要做的事情| 久污tv| 国产91变态冷s调教在线观看| 扩宫虐菊惩罚调教扩张小说| 国精产品自偷自偷综合| 成色好P31s| 黄色一级二级| 国产日韩欧美一区二区三区综合| 纯h超级大尺度| 国产精品第69页| 恋母电影| 欧美aa在线观看| 欧美猛男超大videosgay| 大胸美女被cao哭| 亚洲 变态 欧美 另类 精品| 日本伦理电影禁忌完整在线观看| 〖短篇〗变身尤物H女| 大伊香蕉精品一区在线| 欧美男同猛男videos同性| 久久精品亚洲AV无码乱码三区| 男生脱美女内裤一边脱一边摸| 91精品国产综合久久香蕉第1集 | 黄色片免费在线看| 欧产?日产?国产精品VR| 日本高清???精品| 强制play纯肉高H侵犯| 波多野结衣电影在线观看|