MySQL存储引擎

MySQL存储引擎

完整的建表语句

CREATE TABLE `t_abc‘ (
		`id` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

注意:在MySQL当中,凡是标识符是可以使用“ ``  ”(飘号)括起来的。最好别用,不通用。

建表的时候可以指定存储引擎,也可以指定字符集。

MySQL默认使用的存储引擎是InnoDB方式。
默认采用的字符集是UTF8

什么 是存储引擎呢?

? 存储引擎这个名字只有在MySQL中存在。(Oracle中有对应的机制,但是不叫存储引擎。Oracle中没有特殊的名字,就是“表的存储方式”)

? MySQL支持很多存储引擎,每一个存储引擎都对应了一种不同的存储方式。

? 每一个存储引擎都有自己的优缺点,需要在合适的时机选择合适的存储引擎。

查看当前MySQL支持的存储引擎?

? show engines \G

不同版本的数据库中,对应的存储引擎不同,下面是MySQL5.5版本中的9个存储引擎方式
*************************** 1. row ***************************
      Engine: FEDERATED
     Support: NO
     Comment: Federated MySQL storage engine
Transactions: NULL
          XA: NULL
  Savepoints: NULL
*************************** 2. row ***************************
      Engine: MRG_MYISAM
     Support: YES
     Comment: Collection of identical MyISAM tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 3. row ***************************
      Engine: MyISAM
     Support: YES
     Comment: MyISAM storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 4. row ***************************
      Engine: BLACKHOLE
     Support: YES
     Comment: /dev/null storage engine (anything you write to it disappears)
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 5. row ***************************
      Engine: CSV
     Support: YES
     Comment: CSV storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 6. row ***************************
      Engine: MEMORY
     Support: YES
     Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 7. row ***************************
      Engine: ARCHIVE
     Support: YES
     Comment: Archive storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 8. row ***************************
      Engine: InnoDB
     Support: DEFAULT
     Comment: Supports transactions, row-level locking, and foreign keys
Transactions: YES
          XA: YES
  Savepoints: YES
*************************** 9. row ***************************
      Engine: PERFORMANCE_SCHEMA
     Support: YES
     Comment: Performance Schema
Transactions: NO
          XA: NO
  Savepoints: NO
9 rows in set (0.01 sec)

常见的存储引擎

MyISAM

      Engine: MyISAM
     Support: YES
     Comment: MyISAM storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
  
MyISM这种存储引擎不支持事务。
MyISM是MySQL最常用的存储引擎,但是这种引擎不是默认的。
  
它管理的表具有以下特征:
	-使用三个文件表示每个表:
	-格式文件―存储表结构的定义( mytable.frm)
	-数据文件―存储表行的内容(mytable.MYD)
	-文件―存储表上索引(mytable.MYI)
	-灵活的AUTO_INCREMENT字段处理
	-可被转换为压缩、只读表来节省空间

InnoDB

      Engine: InnoDB
     Support: DEFAULT
     Comment: Supports transactions, row-level locking, and foreign keys
Transactions: YES
          XA: YES
  Savepoints: YES
  
  优点:支持事务、行级锁、外键。这种存储引擎数据的安全得到保障。
  
  表的结构存储在xxx.frm文件中
  数据存储在tablespace这样的表空间中(逻辑概念),无法被压缩,无法转换成只读。
  这种InnoDB存储牵引器在MySQL数据库崩溃之后提供自动恢复
  InnoDB支持级联删除和级联更新

MEMORY

      Engine: MEMORY
     Support: YES
     Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
          XA: NO
  Savepoints: NO
  
  缺点:不支持事务,数据容易丢失。因为所有数据和索引都是存储在内容当中的。
  优点:查询速度最快。
  以前叫做HEPA引擎。

MySQL存储引擎

上一篇:Elasticsearch logstsh同步mysql数据到ES中


下一篇:mysql 设计规范