码迷,mamicode.com
首页 > 数据库 > 详细

mysql存储引擎,并发控制,事务

时间:2015-11-04 07:09:25      阅读:248      评论:0      收藏:0      [点我收藏+]

标签:存储引擎   mysql   mariadb   innodb   myisam   

存储引擎是表级别的概念,每创建一张表都应该指明它的存储引擎,对同一个数据库而言,不建议交叉使用同一个存储引擎。

InnoDB:增强版是xtraDB,mariadb默认使用xtraDB
    处理大量的短期事务;
    数据存储于“表空间(table space)”中;
    (1) 所有InnoDB表的数据和索引放置于同一个表空间中;
        表空间文件:datadir定义的目录下
        数据文件:ibddata1, ibddata2, ...
    (2) 每个表单独使用一个表空间存储表的数据和索引;
        innodb_file_per_table=ON
MariaDB [(none)]> SHOW GLOBAL VARIABLES LIKE ‘innodb_file_per%‘;
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| innodb_file_per_table | OFF   |
+-----------------------+-------+
1 row in set (0.00 sec)
创建t2表:
MariaDB [mydb]> CREATE TABLE t2 (id int, name char(30));
Query OK, 0 rows affected (0.01 sec)
在系统的数据目录下发现了t2表的相关数据
    数据文件(存储数据和索引):tbl_name.ibd, 
    表格式定义:tbl_name.frm
[root@node1 mydb]# ls
db.opt  t1.frm  t2.frm
[root@node1 mydb]# pwd
/var/lib/mysql/mydb

基于MVCC来支持高并发,支持所有的四个隔离级别,默认级别为REPEATABLE READ; 间隙锁防止幻读;
    使用聚集索引
    支持“自适应hash索引”
    锁粒度:行级锁

数据存储:表空间
并发:MVCC, 间隙锁
索引:聚集索引、辅助索引
性能:预计操作、自适应hash、插入缓存区
备份:支持热备(xtrabacup)
MyISAM:
    支持全文索引(FULLTEXT index),innodb不支持、压缩、空间函数(GIS); 但不支持事务,且为表级锁,不支持行级锁;
    崩溃后无法安全恢复
适用场景:只读(或者写较少)、表较小(可以接受长时间进行修复操作)
    Aria:crash-safe
文件:
    tbl_name.frm: 表格式定义
    tbl_name.MYD: 数据文件
    tbl_name.MYI: 索引文件
特性:
    加锁和并发:表级锁
    修复:手工或自动修复、但可能丢失数据
    索引:非聚集索引
    延迟更新索引键:
    压缩表
行格式:dynamic, fixed, compressed, compact, redundent




本文出自 “明天过后” 博客,请务必保留此出处http://leeyan.blog.51cto.com/8379003/1709447

mysql存储引擎,并发控制,事务

标签:存储引擎   mysql   mariadb   innodb   myisam   

原文地址:http://leeyan.blog.51cto.com/8379003/1709447

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!