设置表的存储引擎、InnoDB与MyISAM的对比、Archive、CSV、Memory等存储引擎的使用
# 第05章_存储引擎

# 1. 查看存储引擎

SHOW ENGINES;

# 2. 设置系统默认的存储引擎

# 查看默认的存储引擎

SHOW VARIABLES LIKE '%storage_engine';

SELECT @@default_storage_engine;

SHOW DATABASES;

USE dbtest1;

SHOW TABLES;

CREATE TABLE emp2(id int);

SHOW CREATE TABLE emp2;

# 修改默认的存储引擎

SET DEFAULT_STORAGE_ENGINE=MyISAM;

SELECT @@default_storage_engine;

SHOW ENGINES;

USE dbtest1;

CREATE TABLE emp3(id INT);

SHOW CREATE TABLE emp3;

# 3. 设置表的存储引擎

# 创建表时指定存储引擎

CREATE TABLE emp4(id INT) ENGINE=InnoDB;

SHOW CREATE TABLE emp4;

# 修改表的存储引擎

ALTER TABLE emp4 ENGINE=MyISAM;

SHOW CREATE TABLE emp4;

SET DEFAULT_STORAGE_ENGINE=InnoDB;

SHOW ENGINES;

# 4. 引擎介绍

# 4.1 InnoDB 引擎:具备外键支持功能的事务存储引擎

# MySQL从3.23.34a开始就包含InnoDB存储引擎。 大于等于5.5之后,默认采用InnoDB引擎 。

# InnoDB是MySQL的 默认事务型引擎 ,它被设计用来处理大量的短期(short-lived)事务。
# 可以确保事务的完整提交(Commit)和回滚(Rollback)。

# 除了增加和查询外,还需要更新、删除操作,那么,应优先选择InnoDB存储引擎。

# 除非有非常特别的原因需要使用其他的存储引擎,否则应该优先考虑InnoDB引擎。

# 数据文件结构:(在《第02章_MySQL数据目录》章节已讲)
#     表名.frm 存储表结构(MySQL8.0时,合并在表名.ibd中)
#     表名.ibd 存储数据和索引

# InnoDB是 为处理巨大数据量的最大性能设计 。
#     在以前的版本中,字典数据以元数据文件、非事务表等来存储。现在这些元数据文件被删除了。
# 比如: .frm , .par , .trn , .isl , .db.opt 等都在MySQL8.0中不存在了。

# 对比MyISAM的存储引擎, InnoDB写的处理效率差一些 ,并且会占用更多的磁盘空间以保存数据和索引。

# MyISAM只缓存索引,不缓存真实数据;InnoDB不仅缓存索引还要缓存真实数据, 对内存要求较高 ,
# 而且内存大小对性能有决定性的影响。

# 4.2 MyISAM 引擎:主要的非事务处理存储引擎

# MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等
# ,但MyISAM 不支持事务、行级锁、外键 ,有一个毫无疑问的缺陷就是 崩溃后无法安全恢复 。

# 5.5之前默认的存储引擎

# 优势是访问的 速度快 ,对事务完整性没有要求或者以SELECT、INSERT为主的应用

# 针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高

# 数据文件结构:(在《第02章_MySQL数据目录》章节已讲)
#     表名.frm 存储表结构
#     表名.MYD 存储数据 (MYData)
#     表名.MYI 存储索引 (MYIndex)

# 应用场景:只读应用或者以读为主的业务

# 4.3 Archive 引擎:用于数据存档

# 4.4 Blackhole 引擎:丢弃写操作,读操作会返回空内容

# 4.5 CSV 引擎:存储数据时,以逗号分隔各个数据项

USE dbtest1;

CREATE TABLE csv_demo(id INT NOT NULL,name CHAR(20) NOT NULL) ENGINE = csv;

SHOW CREATE TABLE csv_demo;

SELECT * FROM csv_demo;

INSERT INTO csv_demo(id, name)
VALUES(1,'richie01'),
       (2,'richie02');

SELECT * FROM csv_demo;

# 4.6 Memory 引擎:置于内存的表

# 概述:
# Memory采用的逻辑介质是 内存 , 响应速度很快 ,但是当mysqld守护进程崩溃的时候 数据会丢失 。
# 另外,要求存储的数据是数据长度不变的格式,比如,Blob和Text类型的数据不可用(长度不固定的)。

# 主要特征:
# Memory同时 支持哈希(HASH)索引 和 B+树索引 。

# Memory表至少比MyISAM表要 快一个数量级 。

# MEMORY 表的大小是受到限制 的。表的大小主要取决于两个参数,分别是 max_rows 和max_heap_table_size 。
# 其中,max_rows可以在创建表时指定;max_heap_table_size的大小默认为16MB,可以按需要进行扩大。

# 数据文件与索引文件分开存储。

# 缺点:其数据易丢失,生命周期短。基于这个缺陷,选择MEMORY存储引擎时需要特别小心。

# 使用Memory存储引擎的场景:
# 1. 目标数据比较小 ,而且非常 频繁的进行访问 ,在内存中存放数据,如果太大的数据会造成 内存溢出 。
# 可以通过参数 max_heap_table_size 控制Memory表的大小,限制Memory表的最大的大小。

# 2. 如果 数据是临时的 ,而且 必须立即可用 得到,那么就可以放在内存中。

# 3. 存储在Memory表中的数据如果突然间 丢失的话也没有太大的关系 。

# 4.7 Federated 引擎:访问远程表

# 4.8 Merge引擎:管理多个MyISAM表构成的表集合

# 4.9 NDB引擎:MySQL集群专用存储引擎

# 4.10 引擎对比

# 其实我们最常用的就是 InnoDB 和 MyISAM ,有时会提一下 Memory 。其中 InnoDB 是 MySQL 默认的存储引擎。

# 5. MyISAM和InnoDB

# MySQL5.5之前的默认存储引擎是MyISAM,5.5之后改为了InnoDB。

# 课外补充:

# 1、InnoDB表的优势

# InnoDB存储引擎在实际应用中拥有诸多优势,比如操作便利、提高了数据库的性能、维护成本低等。
# 如果由于硬件或软件的原因导致服务器崩溃,那么在重启服务器之后不需要进行额外的操作。
# InnoDB崩溃恢复功能自动将之前提交的内容定型,然后撤销没有提交的进程,重启之后继续从崩溃点开始执行。
# InnoDB存储引擎在主内存中维护缓冲池,高频率使用的数据将在内存中直接被处理。
# 这种缓存方式应用于多种信息,加速了处理进程。

# 在专用服务器上,物理内存中高达80%的部分被应用于缓冲池。如果需要将数据插入不同的表中,
# 可以设置外键加强数据的完整性。更新或者删除数据,关联数据将会被自动更新或删除。如果试图将数据插入从表,
# 但在主表中没有对应的数据,插入的数据将被自动移除。如果磁盘或内存中的数据出现崩溃,
# 在使用脏数据之前,校验和机制会发出警告。当每个表的主键都设置合理时,与这些列有关的操作会被自动优化。
# 插入、更新和删除操作通过做改变缓冲自动机制进行优化。 InnoDB不仅支持当前读写,
# 也会缓冲改变的数据到数据流磁盘 。

# InnoDB的性能优势不只存在于长时运行查询的大型表。在同一列多次被查询时,自适应哈希索引会提高查询的速度。
# 使用InnoDB可以压缩表和相关的索引,可以 在不影响性能和可用性的情况下创建或删除索引 。
# 对于大型文本和BLOB数据,使用动态行形式,这种存储布局更高效。
# 通过查询INFORMATION_SCHEMA库中的表可以监控存储引擎的内部工作。在同一个语句中,
# InnoDB表可以与其他存储引擎表混用。即使有些操作系统限制文件大小为2GB,InnoDB仍然可以处理。
# 当处理大数据量时,InnoDB兼顾CPU,以达到最大性能 。
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇