mysql的常用引擎
来源:互联网 发布:学说四川话的软件 编辑:程序博客网 时间:2024/05/17 08:44
转载自:https://www.cnblogs.com/xiaohaillong/p/6079551.html
在MySQL数据库中,常用的引擎主要就是2个:Innodb和MyIASM。
首先:
1.简单介绍这两种引擎,以及该如何去选择。
2.这两种引擎所使用的数据结构是什么。
a.Innodb引擎,Innodb引擎提供了对数据库ACID事务的支持。并且还提供了行级锁和外键的约束。它的设计的目标就是处理大数据容量的数据库系统。它本身实际上是基于Mysql后台的完整的系统。Mysql运行的时候,Innodb会在内存中建立缓冲池,用于缓冲数据和索引。但是,该引擎是不支持全文搜索的。同时,启动也比较的慢,它是不会保存表的行数的。当进行Select count(*) from table指令的时候,需要进行扫描全表。所以当需要使用数据库的事务时,该引擎就是首选。由于锁的粒度小,写操作是不会锁定全表的。所以在并发度较高的场景下使用会提升效率的。
b.MyIASM引擎,它是MySql的默认引擎,但不提供事务的支持,也不支持行级锁和外键。因此当执行Insert插入和Update更新语句时,即执行写操作的时候需要锁定这个表。所以会导致效率会降低。不过和Innodb不同的是,MyIASM引擎是保存了表的行数,于是当进行Select count(*) from table语句时,可以直接的读取已经保存的值而不需要进行扫描全表。所以,如果表的读操作远远多于写操作时,并且不需要事务的支持的。可以将MyIASM作为数据库引擎的首先。
补充2点:
c.大容量的数据集时趋向于选择Innodb。因为它支持事务处理和故障的恢复。Innodb可以利用数据日志来进行数据的恢复。主键的查询在Innodb也是比较快的。
d.大批量的插入语句时(这里是INSERT语句)在MyIASM引擎中执行的比较的快,但是UPDATE语句在Innodb下执行的会比较的快,尤其是在并发量大的时候。
2.两种引擎所使用的索引的数据结构是什么?
答案:都是B+树!
MyIASM引擎,B+树的数据结构中存储的内容实际上是实际数据的地址值。也就是说它的索引和实际数据是分开的,只不过使用索引指向了实际数据。这种索引的模式被称为非聚集索引。
Innodb引擎的索引的数据结构也是B+树,只不过数据结构中存储的都是实际的数据,这种索引有被称为聚集索引。
- mysql的常用引擎
- mysql的常用引擎
- MySQL常用的存储引擎
- MySQL常用的存储引擎
- MySQL常用的存储引擎
- MySql常用的存储引擎
- mysql数据库的常用引擎
- mysql几个常用存储引擎的特点
- Mysql数据库常用引擎的介绍
- MySQL中四种常用存储引擎的介绍
- MySQL常用引擎的锁机制
- mysql的常用引擎Innodb和MyIASM
- Mysql数据库常用引擎的介绍
- MySQL中四种常用存储引擎的介绍
- Mysql数据库常用的存储引擎
- mysql的常用引擎:Innodb和MyIASM
- MySQL和oracle的常用引擎介绍
- mysql常用引擎以及各个引擎间的差异
- hdu A Simple Stone Game
- CentOS7配置网卡为静态IP,如果你还学不会那真的没有办法了!
- NOIP2017普及组T2题解
- C#.NET dll封装(包含UI和实现函数),通过反射调用dll实现控件的快速加载(PointListTypeAttributes.cs)
- java:JAVA考试的平均成绩(一维数组)
- mysql的常用引擎
- 两行代码解决你的vs闪退的问题
- 20171110
- webmagic爬取百度知道的问答对并存到数据库
- 色彩表示与编码
- 谈谈redis,memcache的区别和具体应用场景
- spring依赖注入2、注解概述
- Servlet
- 05 C++中智能指针point-like class和仿函数function-like的基本用法(学自Boolean)