IT评测·应用市场-qidao123.com

标题: 5. MySQL 存储引擎(详解分析) [打印本页]

作者: 王柳    时间: 2025-3-7 07:16
标题: 5. MySQL 存储引擎(详解分析)
5.  MySQL 存储引擎(详解分析)

@
目次

这篇文章是我蹲在《尚硅谷》-康师傅博主家的 WiFi 上(不是),连夜 Ctrl+C / V 俩的镇站神文。
这篇转载只是为了,跟各人分享好内容,没有任何商业用途。如果你喜好这篇文章,请一定要去原作者 B站《尚硅谷-MySQL从菜鸟到大牛》看看,说不定还能发现更多宝藏内容呢!
1. 查看存储引擎

  1. show engines;
复制代码

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

  1. show variables like '%storage_engine%';
  2. #或
  3. SELECT @@default_storage_engine;
复制代码

如果在创建表的语句中没有显式指定表的存储引擎的话,那就会默认使用 InnoDB 作为表的存储引擎。 如果我们想改变表的默认存储引擎的话,可以这样写启动服务器的下令行:
  1. SET DEFAULT_STORAGE_ENGINE=MyISAM;
复制代码
或者修改 my.cnf 文件:
  1. default-storage-engine=MyISAM
  2. # 重启服务
  3. systemctl restart mysqld.service
复制代码
3. 设置表的存储引擎

存储引擎是负责对表中的数据举行提取和写入工作的,我们可以为 不同的表设置不同的存储引擎 ,也就是 说不同的表可以有不同的物理存储结构,不同的提取和写入方式。
3.1  创建表时指定存储引擎

我们之前创建表的语句都没有指定表的存储引擎,那就会使用默认的存储引擎 InnoDB 。如果我们想显 式的指定一下表的存储引擎,那可以这么写:
  1. CREATE TABLE 表名(
  2. 建表语句;
  3. ) ENGINE = 存储引擎名称;
复制代码
3.2 修改表的存储引擎

如果表已经建好了,我们也可以使用下边这个语句来修改表的存储引擎:
  1. ALTER TABLE 表名 ENGINE = 存储引擎名称;
复制代码
比如我们修改一下 engine_demo_table 表的存储引擎:
  1. mysql> ALTER TABLE engine_demo_table ENGINE = InnoDB;
复制代码
这时我们再查看一下 engine_demo_table 的表结构:
  1. mysql> SHOW CREATE TABLE engine_demo_table\G
  2. *************************** 1. row ***************************
  3. Table: engine_demo_table
  4. Create Table: CREATE TABLE `engine_demo_table` (
  5. `i` int(11) DEFAULT NULL
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8
  7. 1 row in set (0.01 sec)
复制代码
4. 引擎介绍

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

4.2 MyISAM 引擎:主要的非事务处置处罚存储引擎

4.3 Archive 引擎:用于数据存档


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

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

使用案比方下
  1. mysql> CREATE TABLE test (i INT NOT NULL, c CHAR(10) NOT NULL) ENGINE = CSV;
  2. Query OK, 0 rows affected (0.06 sec)
  3. mysql> INSERT INTO test VALUES(1,'record one'),(2,'record two');
  4. Query OK, 2 rows affected (0.05 sec)
  5. Records: 2 Duplicates: 0 Warnings: 0
  6. mysql> SELECT * FROM test;
  7. +---+------------+
  8. | i |      c     |
  9. +---+------------+
  10. | 1 | record one |
  11. | 2 | record two |
  12. +---+------------+
  13. 2 rows in set (0.00 sec)
复制代码
创建CSV表还会创建相应的元文件 ,用于 存储表的状态 和 表中存在的行数 。此文件的名称与表的名称相 同,后缀为 CSM 。如图所示

如果检查 test.CSV 通过执行上述语句创建的数据库目次中的文件,其内容使用Notepad++打开如下:
  1. "1","record one"
  2. "2","record two"
复制代码
这种格式可以被 Microsoft Excel 等电子表格应用程序读取,甚至写入。使用Microsoft Excel打开如图所示

4.6 Memory 引擎:置于内存的表

概述:
Memory采取的逻辑介质是内存 ,相应速度很快 ,但是当mysqld守卫进程崩溃的时候数据会丢失 。别的,要求存储的数据是数据长度不变的格式,比如,Blob和Text类型的数据不可用(长度不固定的)。
主要特征:
使用Memory存储引擎的场景:
4.7  Federated 引擎:访问远程表

Federated引擎是访问其他MySQL服务器的一个 代理 ,尽管该引擎看起来提供了一种很好的 跨服务 器的机动性 ,但也经常带来问题,因此 默认是禁用的 。
4.8  Merge引擎:管理多个MyISAM表构成的表聚集

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

也叫做 NDB Cluster 存储引擎,主要用于 MySQL Cluster 分布式集群 环境,雷同于 Oracle 的 RAC 集 群。
4.10 引擎对比

MySQL中同一个数据库,不同的表可以选择不同的存储引擎。如下表对常用存储引擎做出了对比。


其实这些东西各人没必要立刻就给记住,列出来的目的就是想让各人明确不同的存储引擎支持不同的功能。
其实我们最常用的就是 InnoDB 和 MyISAM ,偶然会提一下 Memory 。其中 InnoDB 是 MySQL 默认的存储引擎。
5. MyISAM和InnoDB

许多人对 InnoDB 和 MyISAM 的取舍存在疑问,到底选择哪个比力好呢?
MySQL5.5之前的默认存储引擎是MyISAM,5.5之后改为了InnoDB。
6. 最后:

“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。”


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4