失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql常见的存储引擎

mysql常见的存储引擎

时间:2023-12-22 17:47:48

相关推荐

mysql常见的存储引擎

1.什么是存储引擎

不同的技术以及配套的相关功能在 MySQL中被称作存储引擎。存储机制、索引技巧、锁定水平等等。

2.常见操作

查看默认存储引擎

show variables like '%engine%';

查看数据库支持的存储引擎

show engines \G;

show variables like 'have%';#DISABLED表示被禁用

3.常用索引

myisam

不支持事务,也不支持外键,尤其是访问速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用基本都可以使用这个引擎来创建表

每个MyISAM在磁盘上存储成3个文件,其中文件名和表名都相同,但是扩展名分别为:

.frm(存储表定义)

.MYD(MYData,存储数据)

.MYI(MYIndex,存储索引)

数据文件和索引文件可以放置在不同的目录,平均分配IO,获取更快的速度,临时解决空间不足问题

表损坏后,不能被访问,数据库异常重启

CHECK TABLE语句来检查MyISAM表的健康,并用REPAIR TABLE语句修复一个损坏到MyISAM表

3种不同的存储格式:

静态(固定长度)表

存储非常迅速,容易缓存,出现故障容易恢复

缺点是占用的空间通常比动态表多

宽度定义补足空格

动态表

动态表包含变长字段,记录不是固定长度的,这样存储的优点是占用空间较少

频繁的更新删除记录会产生碎片,需要定期执行OPTIMIZE TABLE语句或myisamchk -r命令来改善性能,并且出现故障的时候恢复相对比较困难

压缩表

myisamchk工具创建,占据非常小的空间,因为每条记录都是被单独压缩的,所以只有非常小的访问开支

InnoDB

支持事务安全,写效率差,占用更多的磁盘空间保留数据和索引

自动增长列

InnoDB表的自动增长列可以手工插入,但是插入的值是空或者0,则实际插入的将是自动增长后的值

last_insert_id() 查询当前线程最后插入记录使用值,如果一次插入多条记录,返回的是第一条记录使用的自动增长值

自动增长列必须是索引,如果是组合索引的话,必须是组合索引的第一列

外键约束

只有InnoDB支持索引,创建外键时,要求父表必须有对应的索引,子表也会对应创建对应的索引

删除、更新父表时,对子表进行相应的操作,restrict、cascade、set null和no action

restrict,no action子表有关联的情况下,父表不能更新

cascade 父表在更新或者删除时,更新或者删除子表对应的记录

set null父表在更新或者删除时,子表对应的子段被set null

导入多表数据时,暂停外键检查

如果觉得《mysql常见的存储引擎》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。