mysql存储引擎(一)
来源:互联网 发布:python android接口 编辑:程序博客网 时间:2024/06/04 18:22
mysql各种存储引擎(一)
- mysql各种存储引擎一
- MyISAM
- MyISAM文件格式
- MyISAM文件修复
- MyISAM表的存储格式
- Innodb存储引擎
- 支持事物
- 自动增长列
- 外键约束
- 存储结构
- MyISAM
- mysql各种存储引擎一
MyISAM
MyISAM文件格式
- frm文件 存储表的结构定义数据
- MYD文件 具体的数据文件
- MYI文件 表索引文件
myISAM存储引擎只缓存索引,对数据文件采用操作系统缓存,如果索引数据超过系统所分配的缓存空间时也会采用操作系统来缓存索引.
MyISAM文件修复
- 通过使用check table语句检测MyISAM表的状态,然后用REPAIR TABLE语句修复损坏的表
- 使用myisamchk工具修复,如果有用户同时在操作这张表,那么即使表是没有问题的,也很有可能提示表已损坏,故进行检查时,应当先停掉mysql服务。如果不想停止服务,至少应该mysqladmin flush-tables操作。
[➜ JavaStudy git:(master) myisamchk -e books.MYI Checking MyISAM file: books.MYI Data records: 0 Deleted blocks: 0 - check file-size - check record delete-chain - check key delete-chain - check index reference - check data record references index: 1 - check records and index references
MyISAM表的存储格式
- 静态(固定长度)表 默认格式,固定非变长字段,存储速度快,容易缓存,易恢复,缺点所占空间较多,且利用率不高
- 动态可变长度表,可变长存储,恢复困难,行变化较大时会被分成碎片,需要使用myisamchk -r 来修复
- 压缩表 存储空间最小,每行进行压缩,使用数据库提供的myisanpack工具压缩。
Innodb存储引擎
支持事物
4个事物级别:
- read uncommitted 最低级别,以下情况均无法保证
- read committed 可避免脏读情况发生
- repeatable read 可避免脏读、不可重复读情况的发生 数据库的默认级别
- serializable 可避免脏读、不可重复读、虚读情况的发生
自动增长列
auto_increment属性,表在添加数据的时候,可以插入空值,该列可以自动增加数据
外键约束
它降低了数据库的查询效率,数据库表之间的耦合度更加紧密,要求父表必须有相对应的索引,字表在创建时回添加相应的索引。
存储结构
- .frm文件 数据的结构定义文件
- .ibd文件 数据与索引文件
(1)使用共享表空间
所有的表盒索引数据存放在同一个表空间中,数据和索引在innodb_data_home_dir和innodb_data_file_path定义的表空间中,可以使用一个或多个数据文件
(2)使用多表空间
表结构存放在.frm文件中,但是每个表的数据和索引文件存放在一个单独的.ibd文件中.要使用多表空间存储时,需要设置innodb_file_per_table参数,这样每个数据库的表都会生成一个数据空间
查看如下:
mysql> show variables like '%per_table%'; +-----------------------+-------+ | Variable_name | Value | +-----------------------+-------+ | innodb_file_per_table | ON | +-----------------------+-------+ 1 row in set (0.00 sec)
修改前需要关闭数据库,然后在配置文件my.cnf中设置或者添加该参数innodb_file_per_table = 1,重启数据库服务。
1 0
- mysql存储引擎(一)
- MySQL(一)-存储引擎
- Mysql存储引擎(一)------概述
- 【深入浅出Mysql】MySql存储引擎(一)
- mysql存储引擎相关(一)
- mysql的innodb存储引擎(一)
- MySQL InnoDB存储引擎之表(一)
- MySQL技术内幕 InnoDB存储引擎(一)
- MySQL存储引擎(一)---MyISAM、InnoDB
- 【MySQL】MySQL存储引擎
- 【MySQL】MySQL存储引擎
- Mysql技术内幕InnoDB存储引擎读书笔记--《一》Mysql体系结构和存储引擎
- mysql federated存储引擎引擎
- Mysql innodb存储引擎的性能优化一
- mysql的myisam存储引擎特性(一)
- mysql笔记一(创建库、存储引擎、数据类型)
- MySQL技术内幕-InnoDB存储引擎-读书笔记(一)
- MySQL笔记(一):事物与Innodb存储引擎
- 剑指Offer—查找链表倒数第K个结点
- 菜鸟的安卓之旅之初始篇之一
- oc中特殊字符的判断方法
- volleyjar包,源码导入与关联
- Mysql主从复制
- mysql存储引擎(一)
- 线程的问题
- css盒子模型的示例
- Android中View绘制流程
- 二叉查找树中搜索区间
- mysql connector c++测试
- .NET程序集强命名删除与再签名技术 源代码剖析
- UIButton文字居左显示
- ZOJ 3878-Convert QWERTY to Dvorak【模拟】