Docs/数据库/mysql/Mysql引擎及特性.md
2022-10-18 16:59:37 +08:00

37 lines
No EOL
3.7 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

### InnoDB
```
InnoDB是一个事务型的存储引擎有行级锁定和外键约束
Innodb引擎提供了对数据库ACID事务的支持并且实现了SQL标准的四种隔离级别关于数据库事务与其隔离级别的内容请见数据库事务与其隔离级别这类型的文章。该引擎还提供了行级锁和外键约束它的设计目标是处理大容量数据库系统它本身其实就是基于MySQL后台的完整数据库系统MySQL运行时Innodb会在内存中建立缓冲池用于缓冲数据和索引。但是该引擎不支持FULLTEXT类型的索引而且它没有保存表的行数当SELECT COUNT(*) FROM TABLE时需要扫描全表。当需要使用数据库事务时该引擎当然是首选。由于锁的粒度更小写操作不会锁定全表所以在并发较高时使用Innodb引擎会提升效率。但是使用行级锁也不是绝对的如果在执行一个SQL语句时MySQL不能确定要扫描的范围InnoDB表同样会锁全表。
```
#### 适用场景
```
1经常更新的表适合处理多重并发的更新请求。
2支持事务。
3可以从灾难中恢复通过bin-log日志等
4外键约束。只有他支持外键。
5支持自动增加列属性auto_increment。
```
#### 其他
```
1InnoDB给MySQL提供了具有提交、回滚和崩溃恢复能力的事务安全ACID兼容存储引擎。
2InnoDB锁定在行级并且也在SELECT语句提供一个Oracle风格一致的非锁定读这些特色增加了多用户部署和性能。没有在InnoDB中扩大锁定的需要因为在InnoDB中行级锁定适合非常小的空间。
3InnoDB也支持FOREIGN KEY强制。在SQL查询中你可以自由地将InnoDB类型的表与其它MySQL的表的类型混合起来甚至在同一个查询中也可以混合。
4InnoDB是为处理巨大数据量时的最大性能设计它的CPU效率可能是任何其它基于磁盘的关系数据库引擎所不能匹敌的。
5InnoDB被用来在众多需要高性能的大型数据库站点上产生。
```
### MyISAM
```
MyIASM是MySQL默认的引擎但是它没有提供对数据库事务的支持也不支持行级锁和外键因此当INSERT(插入)或UPDATE(更新)数据时即写操作需要锁定整个表,效率便会低一些。
MyIsam 存储引擎独立于操作系统也就是可以在windows上使用也可以比较简单的将数据转移到linux操作系统上去。
意味着:引擎在创建表的时候,会创建三个文件,一个是.frm文件用于存储表的定义一个是.MYD文件用于存储表的数据另一个是.MYI文件存储的是索引。操作系统对大文件的操作是比较慢的这样将表分为三个文件那么.MYD这个文件单独来存放数据自然可以优化数据库的查询等操作。有索引管理和字段管理。MyISAM还使用一种表格锁定的机制来优化多个并发的读写操作其代价是你需要经常运行OPTIMIZE TABLE命令来恢复被更新机制所浪费的空间。
```
#### 适用场景
```
1不支持事务的设计但是并不代表着有事务操作的项目不能用MyIsam存储引擎可以在service层进行根据自己的业务需求进行相应的控制。
2不支持外键的表设计。
3查询速度很快如果数据库insert和update的操作比较多的话比较适用。
4整天 对表进行加锁的场景。
5MyISAM极度强调快速读取操作。
6MyIASM中存储了表的行数于是SELECT COUNT(*) FROM TABLE时只需要直接读取已经保存好的值而不需要进行全表扫描。如果表的读操作远远多于写操作且不需要数据库事务的支持那么MyIASM也是很好的选择。
```