小贝_mysql常见存储引擎区别_MySQL
存储引擎区别
简要:
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进行重置 |
仅被存储在主内存中,而不是存在磁盘上 |
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文件。其中这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Ces dernières années, le moteur de modèles dans la programmation PHP est devenu un élément important du développement PHP, permettant aux programmeurs de développer et de gérer plus facilement des pages. Cet article présentera les moteurs de modèles courants dans la programmation PHP. SmartySmarty est un moteur de modèles PHP couramment utilisé. Il prend en charge une série de fonctions telles que des modèles en cache, des modules de plug-in et des fonctions personnalisées. La syntaxe de Smarty est très flexible et peut résoudre le problème de la combinaison de variables PHP avec des balises HTML, rendant le langage PHP plus adapté à la conception basée sur des modèles. De plus, S

Le PNJ intelligent créé par l'académicien Huang dans « Cyberpunk 2077 » parle déjà chinois ? L'expérience directe de Qubit, voir des PNJ converser couramment en chinois et en anglais, avec des expressions et des mouvements naturels, et des formes de bouche assorties... S'il n'y avait pas d'écran devant moi, j'aurais vraiment l'impression d'y être. Lors du salon CES de cette année, Nvidia a utilisé son moteur intelligent Avatar Cloud Engine (ACE) pour rendre les PNJ du jeu « vivants », ce qui a provoqué un véritable choc. △Le PNJ intelligent présenté au CES utilise ACE. Les personnages du jeu peuvent avoir des conversations vocales réalistes avec les joueurs, tout en montrant des expressions et des mouvements corporels vifs sans avoir à préparer un script à l'avance. Au moment de ses débuts, il y avait Ubisoft, Tencent, NetEase, MiHoYo et d'autres pays.

Selon les informations du 8 octobre, le marché automobile américain subit un changement sous le capot. Les moteurs à six et huit cylindres, autrefois appréciés, perdent progressivement leur domination, tandis que les moteurs à trois cylindres font leur apparition. Les informations du 8 octobre ont montré que le marché automobile américain subit actuellement un changement sous le capot. Les moteurs à six et huit cylindres bien-aimés du passé perdent progressivement leur domination et le moteur à trois cylindres commence à émerger. Dans l'esprit de la plupart des gens, les Américains aiment les modèles de grande cylindrée et le « gros V8 américain ». a toujours été synonyme de voitures américaines. Cependant, selon des données récemment publiées par des médias étrangers, le paysage du marché automobile américain subit d’énormes changements et la bataille sous le capot s’intensifie. Il est entendu qu'avant 2019, les États-Unis

L'éclairage global en temps réel (Real-time GI) a toujours été le Saint Graal de l'infographie. Au fil des années, l’industrie a proposé diverses méthodes pour résoudre ce problème. Les méthodes courantes incluent la contrainte du domaine du problème en utilisant certaines hypothèses, telles que la géométrie statique, une représentation approximative de la scène ou le suivi de sondes approximatives, et l'interpolation de l'éclairage entre les deux. Dans Unreal Engine, la technologie globale du système d'éclairage et de réflexion Lumen a été fondée par Krzysztof Narkowicz et Daniel Wright. L'objectif était de créer une solution différente de ses prédécesseurs, capable d'un éclairage uniforme et d'une qualité d'éclairage semblable à celle d'un four. Récemment, au SIGGRAPH 2022, Krzysztof Narko

Redmi a officiellement annoncé aujourd'hui que le nouveau Redmi GPro 2024 sortira officiellement le 4 mars. En d’autres termes, la semaine prochaine, nous aurons la sortie de ce nouveau produit passionnant. RedmiGPro2024 fait ses débuts en tant que produit phare de l'e-sport, intégrant profondément les capacités de l'industrie de la téléphonie mobile dans le secteur des ordinateurs portables, présentant une version super performante de 210 W et les performances de Redmi atteignant un nouveau sommet. Equipé d'un processeur i9-14900HX et d'une carte graphique RTX4060, il allie parfaitement e-sport et création pour réaliser une double évolution. De ce point de vue, les performances de ce nouveau produit seront encore améliorées et l'effet réel est passionnant. Il a été mentionné lors de l'échauffement officiel que le nouveau Redmi G Pro 2024 apporte la version PC du moteur violent. Autonomisation de la technologie de téléphonie mobile, trois facteurs majeurs conduisent

Les scénarios d'application courants de l'attribut position dans le développement H5 nécessitent des exemples de code spécifiques. Dans le développement H5, l'attribut position du CSS est très important. Il contrôle le positionnement des éléments dans la page Web. En appliquant correctement l’attribut position, nous pouvons obtenir flexibilité et beauté dans la mise en page. Dans cet article, nous présenterons des scénarios d'application courants de l'attribut position et les illustrerons avec des exemples de code spécifiques. Statique (positionnement statique) : la valeur par défaut de l'attribut de position est st

Les variables super globales sont un concept très important en PHP. Elles peuvent accéder aux valeurs des variables n'importe où dans le programme sans utiliser de fonctions ou d'autres méthodes pour transmettre des variables. Dans cet article, nous aborderons plusieurs variables super globales couramment utilisées dans la programmation PHP. $_GET$_GET est l'une des variables super globales utilisées pour collecter les données soumises par les formulaires HTML. Grâce à $_GET, nous pouvons obtenir les paramètres de chaîne de requête dans l'URL spécifiée. Ces paramètres peuvent être utilisés pour des opérations telles que le filtrage des données ou la requête de données sur la page. Par exemple, quand

Pour résoudre les problèmes de moteur lorsque SAS se connecte à la base de données Oracle, des exemples de code spécifiques sont requis. Lors de l'utilisation du logiciel SAS pour l'analyse des données, il est souvent nécessaire de se connecter à la base de données pour obtenir des données à analyser et à traiter. Parmi elles, la connexion à la base de données Oracle est une opération relativement courante. Cependant, des problèmes de moteur surviennent parfois lors de la connexion à la base de données Oracle, entraînant l'échec de la connexion ou son mauvais fonctionnement. Cet article explique comment résoudre les problèmes de moteur lors de la connexion à la base de données Oracle dans le logiciel SAS et fournit un code spécifique.
