Jadual Kandungan
存储引擎区别
一、存储引擎
二、Myisam与Innodb的区别
Rumah pangkalan data tutorial mysql 小贝_mysql常见存储引擎区别_MySQL

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

Jun 01, 2016 pm 12:59 PM
biasa enjin

存储引擎区别

简要:
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文件。其中这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Perubahan landskap enjin: Enjin tiga silinder mencabar penguasaan enam silinder dan lapan silinder Perubahan landskap enjin: Enjin tiga silinder mencabar penguasaan enam silinder dan lapan silinder Oct 08, 2023 pm 10:57 PM

Menurut berita pada 8 Oktober, pasaran kereta A.S. sedang mengalami perubahan di bawah hud Enjin kuasa enam silinder dan lapan silinder yang digemari sebelum ini secara beransur-ansur kehilangan penguasaannya, manakala enjin tiga silinder muncul. Berita pada 8 Oktober menunjukkan bahawa pasaran kereta A.S. sedang mengalami perubahan di bawah hud. Enjin kuasa enam silinder dan lapan silinder yang digemari pada masa lalu secara beransur-ansur kehilangan penguasaannya, dan enjin tiga silinder mula muncul Dalam fikiran kebanyakan orang, orang Amerika menyukai model anjakan besar, dan "American big V8". sentiasa sinonim dengan kereta Amerika. Bagaimanapun, menurut data yang dikeluarkan baru-baru ini oleh media asing, landskap pasaran kereta A.S. sedang mengalami perubahan yang besar, dan pertempuran di bawah hud semakin sengit. Difahamkan sebelum 2019, Amerika Syarikat

Rendering super realistik! Pakar teknologi Unreal Engine menerangkan sistem pencahayaan global Lumen Rendering super realistik! Pakar teknologi Unreal Engine menerangkan sistem pencahayaan global Lumen Apr 08, 2023 pm 10:21 PM

Pencahayaan global masa nyata (GI masa nyata) sentiasa menjadi grail suci grafik komputer. Selama bertahun-tahun, industri telah mencadangkan pelbagai kaedah untuk menyelesaikan masalah ini. Kaedah biasa termasuk mengekang domain masalah dengan menggunakan andaian tertentu, seperti geometri statik, perwakilan pemandangan kasar, atau mengesan kuar kasar dan interpolasi pencahayaan antara keduanya. Dalam Enjin Unreal, sistem pencahayaan dan pantulan global teknologi Lumen diasaskan oleh Krzysztof Narkowicz dan Daniel Wright. Matlamatnya adalah untuk membina penyelesaian yang berbeza daripada pendahulunya, mampu mencapai pencahayaan seragam dan kualiti pencahayaan seperti bakar. Baru-baru ini, di SIGGRAPH 2022, Krzysztof Narko

Apakah enjin templat biasa dalam pengaturcaraan PHP? Apakah enjin templat biasa dalam pengaturcaraan PHP? Jun 12, 2023 am 09:50 AM

Dalam beberapa tahun kebelakangan ini, enjin templat dalam pengaturcaraan PHP telah menjadi bahagian penting dalam pembangunan PHP, menjadikannya lebih mudah bagi pengaturcara untuk membangun dan mengurus halaman. Artikel ini akan memperkenalkan enjin templat biasa dalam pengaturcaraan PHP. SmartySmarty ialah enjin templat PHP yang biasa digunakan Ia menyokong satu siri fungsi seperti templat cache, modul pemalam dan fungsi tersuai. Sintaks Smarty sangat fleksibel dan boleh menyelesaikan masalah menggabungkan pembolehubah PHP dengan tag HTML, menjadikan bahasa PHP lebih sesuai untuk reka bentuk templat. Selain itu, S

Ujian sebenar enjin permainan NVIDIA AI: sembang masa nyata dengan NPC, bahasa Cina fasih Ujian sebenar enjin permainan NVIDIA AI: sembang masa nyata dengan NPC, bahasa Cina fasih Mar 04, 2024 am 09:40 AM

NPC pintar yang dicipta oleh Ahli Akademik Huang dalam "Cyberpunk 2077" sudah boleh berbahasa Cina? Pengalaman tangan pertama Qubit, menyaksikan NPC bercakap dengan fasih dalam bahasa Cina dan Inggeris, dengan ekspresi dan pergerakan semula jadi, dan bentuk mulut yang sepadan... Jika tidak ada skrin di hadapan saya, rasanya seperti berada di sana. Pada pameran CES tahun ini, Nvidia menggunakan enjin pintarnya Avatar Cloud Engine (ACE) untuk menjadikan NPC permainan "hidup", yang menyebabkan agak mengejutkan. △NPC pintar yang dipaparkan di CES menggunakan ACE Watak dalam permainan boleh mempunyai perbualan suara yang realistik dengan pemain, sambil menunjukkan ekspresi dan pergerakan badan yang jelas tanpa perlu menyediakan skrip terlebih dahulu. Pada masa debutnya, terdapat Ubisoft, Tencent, NetEase, MiHoYo dan negara lain.

Redmi G Pro 2024 Jumpa anda pada 4 Mac, dengan penyejukan ais dan sokongan versi PC enjin yang ganas Redmi G Pro 2024 Jumpa anda pada 4 Mac, dengan penyejukan ais dan sokongan versi PC enjin yang ganas Mar 02, 2024 pm 12:19 PM

Redmi secara rasmi hari ini mengumumkan bahawa Redmi GPro 2024 baharu akan dikeluarkan secara rasmi pada 4 Mac. Dalam erti kata lain, minggu depan kami akan mengeluarkan produk baharu yang menarik ini. RedmiGPro2024 membuat debut penuhnya sebagai perdana e-sukan, menyepadukan dengan mendalam keupayaan industri telefon mudah alih ke dalam perniagaan notebook, mempersembahkan keluaran prestasi super 210W dan prestasi Redmi mencapai tahap tertinggi baharu. Dilengkapi dengan pemproses i9-14900HX dan kad grafik RTX4060, ia menggabungkan e-sukan dan penciptaan dengan sempurna untuk mencapai evolusi dwi. Dari sudut pandangan ini, prestasi produk baru ini akan dipertingkatkan lagi, dan kesan sebenar adalah mengujakan. Telah disebut dalam pemanasan rasmi bahawa Redmi G Pro 2024 baharu membawakan versi PC enjin ganas. Pemerkasaan teknologi telefon mudah alih, tiga faktor utama memimpin

Senario aplikasi biasa atribut kedudukan dalam pembangunan H5 Senario aplikasi biasa atribut kedudukan dalam pembangunan H5 Dec 27, 2023 am 10:08 AM

Senario aplikasi biasa atribut kedudukan dalam pembangunan H5 memerlukan contoh kod khusus Dalam pembangunan H5, atribut kedudukan CSS adalah sangat penting. Dengan menggunakan atribut kedudukan dengan betul, kita boleh mencapai fleksibiliti dan keindahan dalam reka letak halaman. Dalam artikel ini, kami akan memperkenalkan senario aplikasi biasa bagi atribut kedudukan dan menggambarkannya dengan contoh kod khusus. Statik (kedudukan statik): Nilai lalai atribut kedudukan ialah st

Apakah pembolehubah super global biasa dalam pengaturcaraan PHP? Apakah pembolehubah super global biasa dalam pengaturcaraan PHP? Jun 12, 2023 am 09:31 AM

Pembolehubah super global adalah konsep yang sangat penting dalam PHP Mereka boleh mengakses nilai pembolehubah di mana-mana dalam program tanpa menggunakan fungsi atau kaedah lain untuk lulus pembolehubah. Dalam artikel ini, kita akan membincangkan beberapa pembolehubah super global yang biasa digunakan dalam pengaturcaraan PHP. $_GET$_GET ialah salah satu pembolehubah super global yang digunakan untuk mengumpul data yang diserahkan oleh borang HTML. Melalui $_GET, kami boleh mendapatkan parameter rentetan pertanyaan dalam URL yang ditentukan Parameter ini boleh digunakan untuk operasi seperti penapisan data atau pertanyaan data pada halaman. Sebagai contoh, apabila

Bapa Gmail: Dengan ChatGPT, enjin carian tidak akan bertahan lebih daripada dua tahun Bapa Gmail: Dengan ChatGPT, enjin carian tidak akan bertahan lebih daripada dua tahun Apr 14, 2023 pm 01:22 PM

Sejak ChatGPT dilahirkan, Microsoft sepatutnya berasa bertuah. Selain gembira kerana $1 bilion yang saya laburkan beberapa tahun lalu tidak sia-sia. Lebih penting lagi, ChatGPT adalah pasukan yang mesra, bukan lawan. Suasana syarikat teknologi utama lain sangat rumit, terutamanya pesaing lama Microsoft, Google. Paul Buchheit, seorang pekerja veteran Google dan salah seorang pencipta Gmail, baru-baru ini berkata bahawa bot sembang kecerdasan buatan seperti ChatGPT akan memusnahkan Google, sama seperti enjin carian menghapuskan buku telefon halaman kuning sepenuhnya. Mengenai masa, ia hanya satu atau dua tahun. Buchheit tweet pada hari Rabu: "Ia mungkin hanya mengambil masa satu atau dua tahun untuk Google sepenuhnya terganggu. AI akan memadamkan halaman hasil enjin carian, walaupun selepas

See all articles