mysql-innodb与myisam分析


innodb

innodb在主索引文件上直接存放改行数据,次索引指向对主键的引用,同时也叫作聚簇索引

1.主键索引既存储索引值,又在叶子中存储行的数据

2.如果没有主键,则会自动产生unique key做主键

3.如果没有unique唯一键,则会自动生成一个内部的rowid做唯一键

4.支持事务处理与外键和行级锁,但是操作非主键数据行都会锁全表

5.通过使用MVCC(多版本并发控制:读不会阻塞写,写也不会阻塞读)来获得高并发性,并且实现了SQL标准的4种隔离级别(默认为REPEATABLE级别)

6.提供了插入缓冲(insert buffer)、二次写(double write)、自适应哈希索引(adaptive hash index)、预读(read ahead)等高性能和高可用的功能;

7.InnoDB所有的表都保存在同一个数据文件 ibdata中,备份方便。


劣势:

1.如果碰到不规则数据插入时,会造成频繁的页分裂,插入速度变慢,所以主键值最好是连续增长的值,不要设置类似的随机值

2.索引和数据紧密捆绑,没有使用压缩从而会造成Innodb数据库体积大

3.不支持全文索引


myisam

1.不支持行级锁定,只支持锁定整个表,

2.默认写请求的优先级高,这样会阻塞大量的查请求

3.支持全文索引,对char、 varchar和text中的每个词(停用词除外)建立倒排序索引

4.支持GIS数据,innodb不支持

5.MyISAM存储引擎表由MYD和MYI组成,MYD用来存放数据文件,MYI用来存放索引文件。

6.MySQL数据库只缓存其索引文件,数据文件的缓存交给操作系统本身来完成;

7.myisam主索引和次索引都指向物理磁盘







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值