文胜 发表于 2023-7-24 19:44:38

Mysql高级1-存储引擎

一、Mysql体系结构

  
   1.1、连接层

    最上层是一个客户端和链接服务,主要完成一些类似于链接处理,授权认证,及相关的安全方案,服务器也会为安全接入的而每个客户端验证它所具有的操作权限
  1.2、服务层

    第二层架构主要完成大多数的核心服务功能,如SQL接口,并完成缓存的查询,SQL的分析和优化,部分内置函数的执行,所有跨存储引擎的功能叶子啊这一层实现如函数等。
  1.3、引擎层

    存储引擎真正的负责了Mysql中数据的存储和提起,服务器通过api和存储引擎进行通信,不同的存储引擎具有不同的功能,这样我们可以根据自己的需要,来选取合适的存储引擎
  1.4、存储层

    主要是将数据存储在文件系统之上,并完成与存储引擎的交互
 
二、存储引擎介绍

  2.1、简介:

    存储引擎就是存储数据,建立索引,更新/查询数据等技术的实现方式,存储引擎是基于表的,而不是基于库的,所以存储引擎也可以被称为表类型
  2.2、指定引擎语法

create table 表名(
   字段1 字段1类型 ,
   ......
   字段2 字段n类型
)engine=InnoDB ;    说明:mysql5.5之后默认的储存引擎就是InnoDB类型
 
  2.3、查看数据库支持的存储引擎类型:show engines;

mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                      | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| ARCHIVE            | YES   | Archive storage engine                                       | NO         | NO   | NO         |
| BLACKHOLE          | YES   | /dev/null storage engine (anything you write to it disappears) | NO         | NO   | NO         |
| MRG_MYISAM         | YES   | Collection of identical MyISAM tables                        | NO         | NO   | NO         |
| FEDERATED          | NO      | Federated MySQL storage engine                                 | NULL         | NULL | NULL       |
| MyISAM             | YES   | MyISAM storage engine                                          | NO         | NO   | NO         |
| PERFORMANCE_SCHEMA | YES   | Performance Schema                                             | NO         | NO   | NO         |
| InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys   | YES          | YES| YES      |
| MEMORY             | YES   | Hash based, stored in memory, useful for temporary tables      | NO         | NO   | NO         |
| CSV                | YES   | CSV storage engine                                             | NO         | NO   | NO         |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.01 sec) 
三、InnoDB引擎

  3.1、Innodb引擎介绍

    InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,在Mysql5.5之后,InnoDB是默认的Mysql存储引擎
  3.2 InnoDB引擎特点


[*]

[*]DML操作遵循ACID模型,支持事务; 
[*]行级锁,提高并发访问性能
[*]支持外键foreign key约束,保证数据的完整性和正确性   

  3.3 InnoDB引擎文件

    xxx.ibd: xxx代表表名,InnoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frm,sdi)、数据和索引
    参数:innodb_file_per_table 默认打开的,每一张表都有一个独立的表结构 
  3.4 InnoDB引擎的逻辑存储结构

  
 
四、MyISAM引擎

  4.1 MyISAM引擎介绍

    MyISAM是Mysql5.5以前的默认储存
  4.2 MyISAM引擎特点


[*]

[*]不支持事务,不支持外键
[*]支持表锁,不支持行锁
[*]访问速度快

  4.3 MyISAN引擎文件


[*]

[*]xxx.sdi:储存表结构信息
[*]xxx.MYD:储存数据
[*]xxx.MYI:储存索引  

 
五、Memory引擎

  5.1 Memory引擎介绍

    Memory引擎的表数据是存储在内存中的,由于收到硬件问题,或断电问题的影响,只能将这些表作为临时表或者缓存表使用
  5.2 Memory引擎特点


[*]

[*]内存存放,读取速度块
[*]hash索引

  5.3 Memory文件

    xxx.sdi:存储表结构信息
 
六、储存引擎特点对比

  
 
七、存储引擎选择

  1、InnoDB引擎

    InnoDB是Mysql的默认储存引擎,支持事务,外键,如果应用对事务的完整性有比较高的要求,并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包括很多的更新,删除操作,那么InnoDB储存引擎是比较合适的选择。
  2、MyISAM引擎

    如果是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性,并发性要求不是很高,那么选择这个储存引擎是非常合适的,
  3、Memory引擎

    将所有的数据保存在内存中,访问速度块,通常用于临时表及缓存,Memory的缺陷就是对表的大小限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。
 

来源:https://www.cnblogs.com/Se7eN-HOU/p/17577501.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: Mysql高级1-存储引擎