目录
存储引擎区别
一、存储引擎
二、Myisam与Innodb的区别
首页 数据库 mysql教程 小贝_mysql常见存储引擎区别_MySQL

小贝_mysql常见存储引擎区别_MySQL

Jun 01, 2016 pm 12:59 PM
常见 引擎

存储引擎区别

简要:
1、存储引擎
2、myisam与innodb区别

 

一、存储引擎

1、什么是存储引擎

通俗地讲就是存储和管理数据的方式

形象例子:

某处地方的自行车管理员:李某,张某。每天都有很多人来存取自行车。李某的管理方式是: 车主自行存放,李某也不记录对方存的是什么车。取车时则要交管理费。也不检查取的是否是对方自己的车。相反,张某,则在车主存放车时,记录存放人的特征以及对应车的信息。当人来取车时,张某还要小心核对,人与车的特征是否对应。

从上述例子可知:

a、从效率的角度来看: 李某比张某快,因为其不用进行校对

b、从安全性的角度来看: 张某比李某要安全,因为其进行了校对。

总结: 实际上,mysql的存储引擎也是这样工作,每种存储引擎都有自身的存取方式,因此在选择上,应该根据实际情况来定。

 

2、查看mysql所有引擎

mysql>show engines;

 

二、Myisam与Innodb的区别

之所以要区分这两种存储引擎,是因为它们是目前使用最频繁的mysql引擎,因此有必要对它们进行区分。有利于在实际情况下进行灵活运用。

1、myisam存储引擎

a、表构成

建立表mytest

 

create table mytest(id int unsigned,content char(5))engine=myisam;

表对应磁盘的文件

 

总结:

a1、后缀名为:frm为表结构文件,MYD为数据文件,MYI为索引文件

a2、建立myisam引擎的表,都会建立这三个文件,在进行mysql数据库备份或转移时,方便操作

b、批量插入数据

插入1000行数据

 

c、查询表的条数

 

总结: 从截图可以看到mysiam有对表的行数进行记录,而不是需要一条条去记录

d、是否支持事务

 

总结: myisam不支持事务,因此如果你在数据库进行事务操作,但是事务无法成功,你就要看你的表引擎了,看这种引擎是否支持事务。

e、对auto_increment列的操作(修改表mytest的id列)

 

插入数据

 

删除id为3的数据,然后在插入数据

 

这时发现,删除id为3后,继续添加的数据,id并不是从3开始,而是跳过3,从4开始算起。

处理方案:

删除数据后,重置auto_increment

 

总结: myisam引擎的表会对表中auto_increment进行存放,存放在文件磁盘上。即使是重启服务,也不会丢失。

 

2、innodb存储引擎

a、表结构

建立表myinnodb表

create table myinnodb(id int unsigned,content char(5))engine=innodb;

 

其中,frm为表结构文件,ibd为数据和索引文件

b、批量插入数据 (插入1000行数据)

 

c、查询表总条数

 

总结: innodb引擎的表,在计算总行数时,是一条条算

d、是否支持事务

 

总结: innodb引擎表支持事务操作

e、对auto_increment列的操作(修改表myinnodb的id列)

 

插入数据

 

删除id为3的数据

 

继续插入数据

 

发现这种情况跟myisam引擎的一致。

处理方案:

 

总结: innodb可以对auto_increment进行重置,但其对auto_increnment列仅被存储在主内存中,而不是存在磁盘上

 

重启服务

 

 

3、myisam与innodb的区别

 

myisam

innodb

文件构成

frm、MYD、MYI

frm、ibd

是否支持事务

MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持

InnoDB提供事务支持事务,外部键等高级数据库功能

计算表行数

select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的

InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行

 

锁的粒度

表锁

行锁

对AUTO_INCREMENT的操作

存放在磁盘上,可以通过alter进行重置

仅被存储在主内存中,而不是存在磁盘上

 
myisam innodb
文件构成 frm、MYD、MYI frm、ibd
是否支持事务 MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持 InnoDB提供事务支持事务,外部键等高级数据库功能
计算表行数 select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的 InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行  
锁的粒度 表锁 行锁
对AUTO_INCREMENT的操作 存放在磁盘上,可以通过alter进行重置 仅被存储在主内存中,而不是存在磁盘上

 

4、表锁与行锁的区别

在执行数据库写入的操作(insert,update,delete)的时候,mysiam表会锁表,而innodb表会锁行。通俗点说,就是你执行了一个update语句,那么mysiam表会将整个表都锁住,其他的insert和delete、update都会被拒之门外,等到这个update语句执行完成后才会被依次执行。

而锁行,就是说,你执行update语句是,只会将这一条记录进行锁定,只有针对这条记录的其他写入、更新操作会被阻塞并等待这条update语句执行完毕后再执行,针对其他记录的写入操作不会有影响。

 

5、myisam与innodb的选择

a、业务需要支持事务,选择innodb

b、业务查询居多,选择myisam

 

6、总结

MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。如果应用中需要执行大量的SELECT查询,那么MyISAM是更好的选择。

InnoDB用于事务处理应用程序,具有众多特性,包括ACID事务支持。如果应用中需要执行大量的INSERT或UPDATE操作,则应该使用InnoDB,这样可以提高多用户并发操作的性能。

补充:

1、对于innodb的数据结构,首先要先理解两个概念性的问题:共享表空间以及独占表空间。

什么是共享表空间和独占表空间

共享表空间以及独占表空间都是针对数据的存储方式而言的。

共享表空间: 某一个数据库的所有表数据,索引文件全部放在一个文件中,默认这个共享表空间的文件路径在data目录下。默认的文件名为:ibdata1初始化为10M。

独占表空间: 每一张表都将会生成以独立的文件方式来进行存储,每一张表都有一个.frm表描述文件,还有一个.ibd文件。其中这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP编程中有哪些常见的模板引擎? PHP编程中有哪些常见的模板引擎? Jun 12, 2023 am 09:50 AM

最近几年,PHP编程中的模板引擎已经成为了PHP开发的重要组成部分,方便了程序员进行页面开发和管理。本文将介绍PHP编程中常见的模板引擎。SmartySmarty是一个比较常用的PHP模板引擎,它支持缓存模板、插件模块和自定义函数等一系列功能。Smarty的语法十分灵活,能够解决PHP变量与HTML标记的结合难题,使得PHP语言更适用于模板化的设计。而且,S

Redmi G Pro 2024 3 月 4 日见,冰封散热 狂暴引擎 PC 版加持 Redmi G Pro 2024 3 月 4 日见,冰封散热 狂暴引擎 PC 版加持 Mar 02, 2024 pm 12:19 PM

Redmi官方今日宣布,全新RedmiGPro2024将于3月4日正式发布。也就是说,下周我们将迎来这款令人期待的新品发布。RedmiGPro2024以电竞旗舰身份全面登场,将手机产业能力深度融入笔记本业务,呈现210W超强性能释放,Redmi性能再创新高。搭载i9-14900HX处理器和RTX4060显卡,将电竞与创作完美结合,实现双重进化。就此来看,这款新品的性能表现将会再次提升,实际效果如何令人期待。官方预热中提到,全新RedmiGPro2024带来了狂暴引擎PC版。手机技术赋能,三大子引

实测英伟达AI游戏引擎:与NPC实时聊天,中文流畅爆了 实测英伟达AI游戏引擎:与NPC实时聊天,中文流畅爆了 Mar 04, 2024 am 09:40 AM

黄院士在《赛博朋克2077》里搞的智能NPC,已经飙起中文了?量子位的一手体验,亲眼见证了NPC们流利地用中英双语对话,表情动作自然,口型也能对上……如果不是眼前就有一块屏幕,真的会有种身临其境之感。今年的CES展会上,英伟达用智能引擎AvatarCloudEngine(ACE),让游戏NPC“活”了起来,引起了不小的震撼。△CES上展示的智能NPC使用ACE,游戏中的角色可以与玩家进行逼真的语音对话,同时展现出生动的表情和肢体动作,而无需提前准备剧本。亮相当时,就有育碧、腾讯、网易、米哈游等国

超逼真渲染!虚幻引擎技术大牛解读全局光照系统Lumen 超逼真渲染!虚幻引擎技术大牛解读全局光照系统Lumen Apr 08, 2023 pm 10:21 PM

实时全局光照(Real-time GI)一直是计算机图形学的圣杯。多年来,业界也提出多种方法来解决这个问题。常用的方法包通过利用某些假设来约束问题域,比如静态几何,粗糙的场景表示或者追踪粗糙探针,以及在两者之间插值照明。在虚幻引擎中,全局光照和反射系统Lumen这一技术便是由Krzysztof Narkowicz和Daniel Wright一起创立的。目标是构建一个与前人不同的方案,能够实现统一照明,以及类似烘烤一样的照明质量。近期,在SIGGRAPH 2022上,Krzysztof Narko

引擎格局变革:三缸发动机挑战六缸和八缸统治地位 引擎格局变革:三缸发动机挑战六缸和八缸统治地位 Oct 08, 2023 pm 10:57 PM

10月8日消息,美国汽车市场正在经历一场引擎盖下的变革,以前备受喜爱的六缸和八缸动力发动机正逐渐失去统治地位,而三缸发动机则崭露头角。10月8日的消息显示,美国汽车市场正在经历一场引擎盖下的变革。过去备受喜爱的六缸和八缸动力发动机正在逐渐失去统治地位,而三缸发动机则开始崭露头角在大多数人的印象中,美国人钟情于大排量车型,而"美式大V8"一直是美国车的代名词。然而,根据外媒近期公布的数据,美国汽车市场的格局正在发生巨大变化,引擎盖下的战斗正愈演愈烈。据了解,在2019年之前,美

在H5开发中常见的position属性的应用场景 在H5开发中常见的position属性的应用场景 Dec 27, 2023 am 10:08 AM

H5开发中position属性的常见应用场景,需要具体代码示例在H5开发中,CSS的position属性非常重要,它控制元素在网页中的定位方式。通过合理应用position属性,我们可以实现页面布局的灵活性和美观性。在本文中,我们将介绍position属性的常见应用场景,并通过具体的代码示例来说明。Static(静态定位):position属性的默认值为st

PHP网页模板引擎使用方法及常见问题解答 PHP网页模板引擎使用方法及常见问题解答 Jun 08, 2023 pm 12:23 PM

随着互联网技术的不断发展,网页模板引擎成为了网站开发中不可或缺的一部分。PHP网页模板引擎是其中一种常用的网页模板引擎。本文将介绍PHP网页模板引擎的使用方法及常见问题解答。一、什么是PHP网页模板引擎?PHP网页模板引擎是一种将网页设计与业务逻辑分离的技术。采用模板引擎的方式可以将网页的显示与逻辑处理分开,使得代码整洁清晰,易于维护。PHP网页模板引擎与原

解决SAS连接Oracle数据库时出现引擎问题 解决SAS连接Oracle数据库时出现引擎问题 Mar 08, 2024 am 10:12 AM

解决SAS连接Oracle数据库时出现引擎问题,需要具体代码示例在使用SAS软件进行数据分析时,经常需要连接数据库来获取数据进行分析处理。而其中连接Oracle数据库是比较常见的操作。然而,有时候在连接Oracle数据库时会出现引擎问题,导致连接失败或者无法正常操作。本文将介绍如何解决在SAS软件中连接Oracle数据库时出现引擎问题的情况,并提供具体的代码

See all articles