首页 > 数据库 >Mysql高级1-存储引擎

Mysql高级1-存储引擎

时间:2023-07-24 17:33:08浏览次数:42  
标签:存储 NO 引擎 InnoDB MyISAM Mysql YES

一、Mysql体系结构

  

   1.1、连接层

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

  1.2、服务层

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

  1.3、引擎层

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

  1.4、存储层

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

 

二、存储引擎介绍

  2.1、简介:

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

  2.2、指定引擎语法

create table 表名(
   字段1 字段1类型 [comment 字段1注释],
   ......
   字段2 字段n类型 [comment 字段n注释]
)engine=InnoDB [comment 表注释];

    说明: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的缺陷就是对表的大小限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。

 

标签:存储,NO,引擎,InnoDB,MyISAM,Mysql,YES
From: https://www.cnblogs.com/Se7eN-HOU/p/17577501.html

相关文章

  • session 数据库引擎
     如果将setting中的session引擎配置为dbsessionapp的migtaions文件夹中已经包含makemigration数据只需要执行pythonmanage.pymigrate命令这时便会自动创建django_session1的表......
  • Qt mingw73_32 + MySql8.0 使用和对数据库操作 - 初窥篇1
    1、开发环境QtCreator4.8.2+Qt5.12.2+MySql8.0.332、设计背景现在已经有MySql8.0.33是64位的数据库,仅支持64位的程序,但是当前Qt程序编译环境是mingw73_3232位程序连接64位的数据库实例3、操作流程1)测试驱动代码+测试结果intmain(inta......
  • DB2存储过程-基础详解
    DB2存储过程-基础详解关键字:存储过程  您将:学习SQLPL的基本要素。理解如何声明变量、条件和处理程序。学习控制流语句。学习游标处理和如何返回结果集。理解错误处理机制。  Sql代码.-,-----------------. V......
  • Navicat连接Mysql出现“plugin 'caching_sha_password' cannot be loaded”错误
    Navicat连接Mysql出现“plugin'caching_sha_password'cannotbeloaded”错误问题现场​​**官方说明:**​https://dev.mysql.com/doc/refman/8.0/en/caching-sha2-pluggable-authentication.html解决方案使用本地mysql命令行登录;mysql-uroot-p先查一下看看--使用......
  • 如何发现及处理 MySQL 主从延迟问题
    在PerconaMySQL支持团队中,我们经常看到客户抱怨复制延迟的问题。当然,这对MySQL用户来说并不是什么新鲜事,多年来我们在MySQL性能博客上发表过一些关于这个主题的文章(过去有两篇特别受欢迎的文章:"ReasonsforMySQLReplicationLag"和“ManagingSlaveLagwithMySQLRep......
  • Golang 规则引擎原理及实战
    本文主要介绍规则引擎在golang中的使用,将首先介绍golang中主要的规则引擎框架,然后利用golang原生的parser搭建一个简单的规则引擎实现基本的bool表达式解析工作。背景随着业务代码的不断迭代,诞生出了越来越多的if-else,并且if-else中的逻辑越来越复杂,导致代码逻辑复......
  • 各类存储详解
    对象存储、NAS存储和本地存储是三种不同的存储技术,它们在设计和用途上有所不同。1.对象存储(ObjectStorage):对象存储以对象的形式存储数据,每个对象包含数据本身、元数据和唯一的标识符。对象存储通常使用分布式架构,并采用冗余备份策略来实现高可用性和容错性。对象存储适......
  • 使用mysqldump备份数据库时报错表不存在,提示信息Table 'mysql.engine_cost' doesn't e
    问题描述:使用mysqldump备份数据库时报错表不存在,提示信息Table'mysql.engine_cost'doesn'texist,如下所示:数据库:mysql5.7.211、异常重现[mysql@hisdb1~]$mysqldump-uroot-S/mysql/data/mysql.sock-P3306--max_allowed_packet=1G--master-data=2--single-transaction......
  • Ruby实践—连接Mysql
    安装环境:OS:WindowsXPRuby:Ruby1.9.1Mysql:Mysql5.1.46(username/password:root/root port:3306)Ruby-MysqlDriver:mysql-2.8.1-x86-mswin32.gem(注:用2.7.3版本的驱动在测试时会出现require"mysql",找不到指定模块IDE:RubyMine2.0.1 安装Ruby,RubyMine,Mysql的事项在这里就不......
  • 怎么在MYSQL显示默认值
    项目方案:在MySQL中显示默认值1.简介在MySQL中,可以为表的列设置默认值,以确保在插入新记录时,如果没有提供该列的值,将使用默认值作为替代。本项目旨在提供一个方案,用于在MySQL中显示默认值。2.实现方案2.1创建表格首先,我们需要创建一个包含默认值的表格。可以使用以下代码在My......