MySQL学习——存储引擎
mysql在5.5之后的默认存储引擎使用InnoDB,显示mysql版本:
mysql> select version(); +-----------+ | version() | +-----------+ | 5.6.12 | +-----------+ 1 row in set (0.03 sec)
查看支持的存储引擎和当前默认的存储引擎:
mysql> show engines; +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | Engine | Support | Comment | Transactions | XA | Savepoints | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | MyISAM | YES | MyISAM storage engine | NO | NO | NO | | CSV | YES | CSV storage engine | NO | NO | NO | | MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO | | BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO | | MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO | | PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO | | ARCHIVE | YES | Archive storage engine | NO | NO | NO | | InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES | | FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
显示某一表使用的存储引擎:
mysql> use mysql Database changed mysql> show table status like 'user'\G *************************** 1. row *************************** Name: user Engine: MyISAM Version: 10 Row_format: Dynamic Rows: 6 Avg_row_length: 52 Data_length: 312 Max_data_length: 281474976710655 Index_length: 2048 Data_free: 0 Auto_increment: NULL Create_time: 2013-06-23 04:40:03 Update_time: 2013-06-23 04:40:04 Check_time: NULL Collation: utf8_bin Checksum: NULL Create_options: Comment: Users and global privileges 1 row in set (0.00 sec)
其中各个参数的介绍如下:
Name表名 Engine:表的存储引擎。 Row_format:行格式,myisam可以使用的行格式有Dynamic、Fixed、Compressed。Dynamic表示长度可变。 Rows表中的行数 Avg_row_length:平均每行的字节数。 Data_length:整个表的字节数。 Max_data_length:可容纳的最大数据量。 Data_free:已经分配但未使用的空间。 Auto_increment:下一个auto_increment的值。 Create_time:表最初创建的时间。 Update_time:表数据最近被更新的时间。 Check_time:最近被检查的时间。 Collation:默认字符集好排序规则。 Checksum:如果启用,会计算整个表的实时校验和。 Create_options:表创建时的其它所有选项。 Comment:其它说明。
如果要改变默认存储引擎:修改my.cnf
default_storage_engine = ...
MyISAM存储引擎:
对于MyISAM存储引擎,每一个表都有三个文件:
data数据文件,扩展名为.MYD
indexes索引文件,扩展名为.MYI
definition表定义,扩展名为.frm
MyISAM格式是平台通用的,可以在不同架构的服务器上相互拷贝数据文件。MyISAM表可以容纳的行数,一般只受限于数据库服务器的可用从盘空间大小,以及操作系统允许创建的最大文件大小。
MyISAM的特征:
锁:
支持表级锁,但不支持行级锁。读锁在整个表上为共享锁,而写锁为排他锁。用户在运行select时,可以在同一表中并发插入新行。
索引:
支持全文索引。当使用DELAY_KEY_WRITE创建表时,不会立即将改变的索引写入磁盘,而是先写入内存的键缓冲区,在清理缓冲区会关闭表时,在写进磁盘。对于复杂的表,延迟更新索引大大提高了性能。不支持hash索引;支持BTREE、FULLTEXT、RTREE索引。
非事务,不支持外键,支持数据压缩。
InnoDB存储引擎:
对于InnoDB存储引擎,所有的表都只有一个字段:
tablespace 表空间,在表空间中,InnoDB自我管理数据。InnoDB也支持将每个表和索引存储为单独的分离文件。
InnoDB存储引擎是专为事务设计的一款存储引擎。
先介绍一下事务:
事务:一组需要同时执行或不执行的sql语句。事务有4大特性,简称ACID:
1: 原子性 ,要么执行,要么不执行。
2: 一致性,时务执行后,状态完全装换为执行后的状态。
3:隔离性,一个事务在执行过程中产生的数据,其他事务是否能够看到。InnoDB支持4个标准的隔离级别
1.读未提交READ UNCOMMITTED : 可以读别人未提交的(数据)事务
2.读提交READ COMMITTED : 别人未commit时,看到的是原数据,别人提交后,即可看到别人改变后的数据。
3.可重读REPEATABLE READ : 自己所看到的状态是不变的,直到自己提交 (commit)repeatable ,才能看到别人更改的数据,这是InnoDB的默认隔离级别。
4.串行化 SERIALIZABLE:完全隔离级别。别人的事务不提交,自己就处于waiting状态,直到别人提交事务。
显示隔离级别:>SHOW GLOBAL VARIABLES LIKE 'tx_isolation'; 也可以 >SELECT @@tx_isolation;
设定隔离级别:(global全局对所有数据库都生效。session会话只对本会话生效。global后需要重新登入数据库。
全局:SET GLOBAL TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
4:持久性,事务提交会永久存储。
事务的使用方法:
启动事务:>START TRANSACTION;
...
>ROLLBACK //回滚到事务执行前的状态
>SAVE POINT sp_name //保存点
>ROLLBACK sp_name //只回滚到某个保存点
>COMMIT //提交事务
InnoDB引擎特定:
1.支持事务
2.支持行级别的锁
3.支持外键
4.支持自适应的hash索引,支持聚簇、BTREE索引
5.支持可配置的索引缓存和数据缓存大小
6.支持商业工具的在线备份
7.不指定使用事务时,语句执行完成后,服务器隐式自动提交
MyISAM Merge引擎:
Merge引擎是MyISAM的变种,合并表是指将几个相同的MyISAM表合并为一个虚表,对于记录日志和数据仓库的应用很有用。
Memory引擎:
Memory引擎将所有数据存储在内存中,适合于那些需要快速访问数据,且系统重启后数据不需要保存。Memory引擎的查询不需要等待I/O处理,速度非常块。Memory引擎不支持事务,支持表级锁,只支持固定大小的行,比如将VARCHAR类型存储为CHAR,从而节约内存。
NDB Cluster引擎:
NDB Cluster引擎可以满足一些高速性能需求,同时支持冗余和负载均衡特性。它在磁盘上记录日志,但数据保存在内存中。一个NDB数据库有数据节点(data node),管理节点(management node)和sql节点(mysql 实例)组成。么个节点都保存了集群数据中的一段数据。这写片段都是复制未来的,因此在不同的节点上,系统会拥有同一数据的多分拷贝,一台物理服务器通常只专用于一个节点。这种功能类似于服务器级的RAID。
Maria引擎:
Maria引擎设计的目的是为了是为了取代MyISAM,其特点是:可以基于每张表的事务性和非事务性存储;即使运行在非事务性模式下,也能进行崩溃后恢复;支持行级锁;具有更好的blob数据处理功能。
如何选择存储引擎:
选择存储引擎要从多方面考虑:如果需要事务处理操作,那么InnoDB是一个很好的选择;如果不需要事务操作,主要是多读少写时,那么MyISAM是一个比较好的选择。如果只是需要并发的插入操作和读操作,那么MyISAM是一个很好的选择。从备份的角度考虑:如果服务器可以周期性的停机进行备份,那么各种引擎都可满足需求;否则需要根据具体的备份条件进行选择。