登录  /  注册

mysql存储引擎(一)_MySQL

php中文网
发布: 2016-06-08 08:50:37
原创
958人浏览过

mysql各种存储引擎(一)


mysql各种存储引擎一 myisam myisam文件格式 myisam文件修复 myisam表的存储格式 innodb存储引擎 支持事物 自动增长列 外键约束 存储结构

MyISAM

MyISAM文件格式
frm文件 存储表的结构定义数据 MYD文件 具体的数据文件 MYI文件 表索引文件

myISAM存储引擎只缓存索引,对数据文件采用操作系统缓存,如果索引数据超过系统所分配的缓存空间时也会采用操作系统来缓存索引.

MyISAM文件修复
通过使用check table语句检测MyISAM表的状态,然后用REPAIR TABLE语句修复损坏的表 使用myisamchk工具修复,如果有用户同时在操作这张表,那么即使表是没有问题的,也很有可能提示表已损坏,故进行检查时,应当先停掉mysql服务。如果不想停止服务,至少应该mysqladmin flush-tables操作。
<code class="hljs haml">    [?  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
</code>
登录后复制
MyISAM表的存储格式
静态(固定长度)表 默认格式,固定非变长字段,存储速度快,容易缓存,易恢复,缺点所占空间较多,且利用率不高 动态可变长度表,可变长存储,恢复困难,行变化较大时会被分成碎片,需要使用myisamchk -r 来修复 压缩表 存储空间最小,每行进行压缩,使用数据库提供的myisanpack工具压缩。

Innodb存储引擎

支持事物

4个事物级别:<br /> - read uncommitted 最低级别,以下情况均无法保证<br /> - read committed 可避免脏读情况发生<br /> - repeatable read 可避免脏读、不可重复读情况的发生 数据库的默认级别<br /> - serializable 可避免脏读、不可重复读、虚读情况的发生

自动增长列

auto_increment属性,表在添加数据的时候,可以插入空值,该列可以自动增加数据

外键约束

它降低了数据库的查询效率,数据库表之间的耦合度更加紧密,要求父表必须有相对应的索引,字表在创建时回添加相应的索引。

存储结构
.frm文件 数据的结构定义文件 .ibd文件 数据与索引文件

(1)使用共享表空间

所有的表盒索引数据存放在同一个表空间中,数据和索引在innodb_data_home_dir和innodb_data_file_path定义的表空间中,可以使用一个或多个数据文件

(2)使用多表空间

表结构存放在.frm文件中,但是每个表的数据和索引文件存放在一个单独的.ibd文件中.要使用多表空间存储时,需要设置innodb_file_per_table参数,这样每个数据库的表都会生成一个数据空间

查看如下:

<code class="hljs haml"><code class="hljs lua">  mysql> show variables like &#39;%per_table%&#39;;
  +-----------------------+-------+
  | Variable_name         | Value |
  +-----------------------+-------+
  | innodb_file_per_table | ON    |
  +-----------------------+-------+
  1 row in set (0.00 sec)
</code></code>
登录后复制

<code class="hljs lua">修改前需要关闭数据库,然后在配置文件my.cnf中设置或者添加该参数innodb_file_per_table = 1,重启数据库服务。

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号