【MySQL】存储引擎简介、存储引擎特点、存储引擎区别

news2025/8/14 3:26:24

在这里插入图片描述

🐌个人主页: 🐌 叶落闲庭
💨我的专栏:💨
c语言
数据结构
javaEE
操作系统
Redis

石可破也,而不可夺坚;丹可磨也,而不可夺赤。


MySQL

  • 一、MySQL体系结构
  • 二、存储引擎简介
  • 三、存储引擎特点
    • 3.1 InnoDB介绍
    • 3.2 MyISAM介绍
    • 3.3 Memory介绍
  • 四、存储引擎区别(InnoDB、MyISAM 和 Memory)

一、MySQL体系结构

  • 连接层:
  • 最上层是一些客户端和链接服务,主要完成一些类似于连接处理、授权认证、及相关的安全方案。服务器也会为安全接入的每个客户端验证它所具有的操作权限。
  • 服务层:
  • 第二层架构主要完成大多数的核心服务功能,如SQL接口,并完成缓存的查询,SQL的分析和优化,部分内置函数的执行。所有跨存储引擎的功能也在这一层实现,如过程、函数等
  • 引擎层:
  • 存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过AP和存储引擎进行通信。不同的存储引擎具有不同的功能,这样我们可以根据自己的需要,来选取合适的存储引擎
  • 存储层:
  • 主要是将数据存储在文件系统之上,并完成与存储引擎的交互。

二、存储引擎简介

存储引擎是MySQL当中核心的部分,是MySQL当中特有的,是MySQL当中存储数据、建立索引、更新/查询数据等操作的实现方式,不同的存储引擎在实现存储数据、建立索引、更新/查询数据等操作的机制是不一样的,存储引擎是基于表的,而不是基于数据库的,所以在一个数据库下的多张表是可以基于不同的存储引擎的,存储引擎也可被称为表的类型。

  • 查询当前数据库支持的存储引擎:show create table 表名

在这里插入图片描述


  • MySQL默认存储引擎是InnoDB
  • 在创建表时,指定存储引擎:
CREATE TABLE `user` (
  `userId` int NOT NULL AUTO_INCREMENT,
  `userName` varchar(50) NOT NULL,
  `password` varchar(50) NOT NULL,
  `gender` smallint NOT NULL,
  `createTime` datetime DEFAULT NULL,
  `updateTime` datetime DEFAULT NULL,
  PRIMARY KEY (`userId`),
  UNIQUE KEY `userName` (`userName`)
) ENGINE = InnoDB
  • 查看当前数据库支持的存储引擎:
show engines;

在这里插入图片描述


三、存储引擎特点

3.1 InnoDB介绍

  • InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,在MySQL5.5之后,InnoDB是默认的MySQL存储引擎
  • 特点:
  • DML操作遵循ACID模型,支持事务
  • 行级锁,提高并发访问性能
  • 支持外键FOREIGN KEY约束,保证数据的完整性和正确性
  • 文件:
  • xxx.ibd:xxx代表的是表名,innoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frm、sdi)、数据和索引。
  • 参数:innodb_file_per_table

打开MySQL的数据存放目录,选择当前操作的数据库的文件夹,可以看到文件名为表名,后缀名为ibd的文件,也就是每一个InnoDB引擎的表都会有这样的一个表空间文件,在这个表空间文件中,记录了当前数据库的表结构和当前数据库表的数据和索引


在这里插入图片描述


  • 如果想要查看文件中的信息,可以通过cmd的方式,输入cmd指令ib2sdi 表名.ibd
  • 逻辑存储结构:
  • TableSpace:表空间
  • Segment:段
  • Extent:区
  • Page:页
  • Row:行

在这里插入图片描述


3.2 MyISAM介绍

  • MyISAM是MySQL早期的默认存储引擎
  • 特点:
  • 不支持事务,不支持外键
  • 支持表锁,不支持行锁
  • 访问速度快
  • 文件:
  • xxx.sdi:存储表结构信息
  • xxx.MYD:存储数据
  • xxx.MYI:存储索引

xxx.sdi存放的就是表结构信息,可以直接打开,里面是json格式的数据:
xxx.MYD是存放数据的
xxx.MYI是存放索引的

{
    "mysqld_version_id":80031,
    "dd_version":80023,
    "sdi_version":80019,
    "dd_object_type":"Table",
    "dd_object":{
        "name":"my_myisam",
        "mysql_version_id":80031,
        "created":20231012131516,
        "last_altered":20231012131516,
        "hidden":1,
        "options":"avg_row_length=0;key_block_size=0;keys_disabled=0;pack_record=1;stats_auto_recalc=0;stats_sample_pages=0;",
        "columns":[
            {
                "name":"id",
                "type":4,
                "is_nullable":true,
                "is_zerofill":false,
                "is_unsigned":false,
                "is_auto_increment":false,
                "is_virtual":false,
                "hidden":1,
                "ordinal_position":1,
                "char_length":11,
                "numeric_precision":10,
                "numeric_scale":0,
                "numeric_scale_null":false,
                "datetime_precision":0,
                "datetime_precision_null":1,
                "has_no_default":false,
                "default_value_null":true,
                "srs_id_null":true,
                "srs_id":0,
                "default_value":"",
                "default_value_utf8_null":true,
                "default_value_utf8":"",
                "default_option":"",
                "update_option":"",
                "comment":"",
                "generation_expression":"",
                "generation_expression_utf8":"",
                "options":"interval_count=0;",
                "se_private_data":"",
                "engine_attribute":"",
                "secondary_engine_attribute":"",
                "column_key":1,
                "column_type_utf8":"int",
                "elements":[

                ],
                "collation_id":255,
                "is_explicit_collation":false
            },
            {
                "name":"name",
                "type":16,
                "is_nullable":true,
                "is_zerofill":false,
                "is_unsigned":false,
                "is_auto_increment":false,
                "is_virtual":false,
                "hidden":1,
                "ordinal_position":2,
                "char_length":40,
                "numeric_precision":0,
                "numeric_scale":0,
                "numeric_scale_null":true,
                "datetime_precision":0,
                "datetime_precision_null":1,
                "has_no_default":false,
                "default_value_null":true,
                "srs_id_null":true,
                "srs_id":0,
                "default_value":"",
                "default_value_utf8_null":true,
                "default_value_utf8":"",
                "default_option":"",
                "update_option":"",
                "comment":"",
                "generation_expression":"",
                "generation_expression_utf8":"",
                "options":"interval_count=0;",
                "se_private_data":"",
                "engine_attribute":"",
                "secondary_engine_attribute":"",
                "column_key":1,
                "column_type_utf8":"varchar(10)",
                "elements":[

                ],
                "collation_id":255,
                "is_explicit_collation":false
            }
        ],
        "schema_ref":"demo1",
        "se_private_id":18446744073709551615,
        "engine":"MyISAM",
        "last_checked_for_upgrade_version_id":0,
        "comment":"",
        "se_private_data":"",
        "engine_attribute":"",
        "secondary_engine_attribute":"",
        "row_format":2,
        "partition_type":0,
        "partition_expression":"",
        "partition_expression_utf8":"",
        "default_partitioning":0,
        "subpartition_type":0,
        "subpartition_expression":"",
        "subpartition_expression_utf8":"",
        "default_subpartitioning":0,
        "indexes":[

        ],
        "foreign_keys":[

        ],
        "check_constraints":[

        ],
        "partitions":[

        ],
        "collation_id":255
    }
}

3.3 Memory介绍

  • Memory引擎的表数据时存储在内存中的,由于受到硬件问题、或断电问题的影响,只能将这些表作为临时表或缓存使用。
  • 特点:
  • 内存存放
  • 支持hash索引(默认)
  • 文件:
  • xxx.sdi:存储表结构信息

四、存储引擎区别(InnoDB、MyISAM 和 Memory)

特点InnoDBMyISAMMemory
存储限制64TB
事务安全支持 --
锁机制行锁 表锁表锁
B+tree索引支持支持支持
Hash索引--支持
全文索引支持(5.6版本之后)支持-
空间使用N/A
内存使用中等
批量插入速度
支持外键支持 --

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1085621.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

zookeeper应用场景(一)

一、zookeeper客户端api 1、官方Java客户端api 引入zookeeper client依赖 <dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId><version>3.9.0</version> </dependency> 1&#xff09…

解析项目管理任务跟踪器,助力项目进展掌握!

什么是项目管理任务跟踪器&#xff1f;项目管理任务跟踪器是项目经理简化计划、组织和执行项目任务直至完成的重要工具。该工具可帮助他们掌握需要完成的工作、确定收到的工作请求的优先级、完成项目并在预算范围内按时实现目标。 除了布置和跟踪任务之外&#xff0c;项目管理任…

unity2022版本 实现加减进度条

简介 在现代游戏开发中&#xff0c;用户界面 (UI) 扮演着至关重要的角色&#xff0c;它不仅为玩家提供信息&#xff0c;还增强了游戏的可玩性。加减进度条是一种常见的UI元素&#xff0c;它可以用于显示游戏中的进度、倒计时、资源管理和其他关键信息。在这篇博客中&#xff0…

【MySQL入门到精通-黑马程序员】MySQL基础篇-DQL

文章目录 前言一、DQL-介绍二、DQL-语法二、DQL-基本查询三、DQL-条件查询四、DQL-聚合函数五、DQL-分组查询六、DQL-排序查询七、DQL-分页查询八、DQL-执行顺序总结 前言 本专栏文章为观看黑马程序员《MySQL入门到精通》所做笔记&#xff0c;课程地址在这。如有侵权&#xff0…

安全设备和防火墙

文章目录 微步TDP态势感知防火墙防火墙的负载均衡 微步TDP态势感知 安全设备的主要功能在黑名单&#xff0c;只要记住黑名单的功能在哪即可 常用的是威胁选项卡的监控功能&#xff0c;监控模块会把实时的告警列出来&#xff0c;只要列出来就能分析流量是误报还是真实的&#x…

【重拾C语言】九、再论函数(指针、数组、结构体作参数;函数值返回指针、结构体;作用域)

目录 前言 九、再论函数 9.1 参数 9.1.1 参数的传递规则 9.1.2 指针作参数 9.1.3 数组作参数 9.1.4 结构体作参数 a. 直接用结构体变量作函数参数 b. 用指向结构体变量的指针作函数参数 9.2 函数值 9.2.1 返回指针值 9.2.2 返回结构体值 a. 返回结构体值 b. 返回…

高效防汛决策:山海鲸可视化系统助力城市防洪

随着全球气候的变化&#xff0c;自然灾害如洪水、台风等频发&#xff0c;防范洪水成为城市管理者和居民们亟待解决的重要问题。 洪水的威胁 洪水是自然界的杀手之一&#xff0c;不仅会造成大量的财产损失&#xff0c;还可能危害人们的生命安全。因此&#xff0c;预测、监测和有…

自我监督学习日志

学习日志 10.12 一天学不了一分钟&#xff0c;不知道为什么也就是了 今天一定要学一个小时&#xff01; 机器学习就是机器帮我们找一个函数 语音辨识&#xff0c;语音&#xff0c;声音讯号 转化为文字 帮我们找一个人类写不出来的复杂函数 类神经网络 输入 一张图片用一个矩…

2023-10-12 LeetCode每日一题(找出数组的串联值)

2023-10-12每日一题 一、题目编号 2562. 找出数组的串联值二、题目链接 点击跳转到题目位置 三、题目描述 给你一个下标从 0 开始的整数数组 nums 。 现定义两个数字的 串联 是由这两个数值串联起来形成的新数字。 例如&#xff0c;15 和 49 的串联是 1549 。 nums 的 串…

不容易解的题10.10

5.最长回文子串 5. 最长回文子串 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/longest-palindromic-substring/?envTypelist&envIdZCa7r67M给一个字符串&#xff0c;让我们找最长回文子串 这题不用说&#xff0c;回文子串那一定是连续的&#…

【Node.js】路由

基础使用 写法一&#xff1a; // server.js const http require(http); const fs require(fs); const route require(./route) http.createServer(function (req, res) {const myURL new URL(req.url, http://127.0.0.1)route(res, myURL.pathname)res.end() }).listen…

Java从resources文件下载文档,文档没有后缀名

业务场景&#xff1a;因为公司会对excel文档加密&#xff0c;通过svn或者git上传代码也会对文档进行加密&#xff0c;所以这里将文档后缀去了&#xff0c;这样避免文档加密。 实现思路&#xff1a;将文档去掉后缀&#xff0c;放入resources下&#xff0c;获取输入流&#xff0…

12V手电钻保护板如何接线演示

爱做手工的小伙伴们肯定会用到手电钻&#xff0c;那么电池消耗完了&#xff0c;或要换的&#xff0c;或要自己动手做几个备用电源&#xff0c;关键点就是电路保护板的接线。废话不多说&#xff0c;直接上板子看实操。 文章目录 一、线路板图1、输入接线2、输出接线 二、接线方法…

java学习笔记001

java基础 java语言特点 面向对象&#xff0c;强类型&#xff0c;跨平台&#xff0c;解释型 基本概念&#xff08;JVM、JRE、JDK&#xff09; JVM java虚拟机 作用&#xff1a;加载.class文件 JRE Java运行环境 JREJVMJava系统类库 JDK Java开发工具包 JDKJRE编译&a…

英语——方法篇——单词——谐音法+拼音法——50个单词记忆

theatre&#xff0c;剧场&#xff0c;太后th吃eat热re食物&#xff0c;就去剧场了 loud dolphin&#xff0c;做do脸皮厚plh在。。。里 humid&#xff0c;hu湖mi米d的 blender&#xff0c;b爸lend借给er儿。 tragedy&#xff0c;tr土人

笔训【day4】

目录 选择题 1、进制 格式 2、 数组名在&和sizeof后&#xff0c;表数组本身 3、求二维数组某元素地址 ​编辑 ​编辑 4、x x & (x-1) 二进制位1的个数 ​编辑 5、斐波那契递归次数 编程题 1、计算糖果 2、进制转换 选择题 1、进制 格式 十进制转二进制就除…

ARM-day9作业

main.c: #include "uart.h"#include "key_it.h"int main(){char c;char *s;uart4_init(); //串口初始化//中断初始化key_it_config();key3_it_config();//完成GPIO相关初始化all_led_init();//风扇初始化fs_init();//蜂鸣器初始化fmq_init();while(1){…

只有线上出了bug,老板们才知道测试的价值?

有同学说&#xff0c;测试没价值&#xff0c;我们测试团队刚被拆散了。 也有同学说&#xff0c;公司不重视测试&#xff0c;我觉得我们就是测试得太好了。哪天线上出个bug&#xff0c;老板们就知道测试的价值了。 还有人给测试同学规划职业发展路径&#xff0c;就是不做测试&…

C语言 —— 操作符

1. 操作符的分类 算术操作符: - * / % 移位操作符: << >> 位操作符: & | ^ 赋值操作符: - 单目操作符 关系操作符 逻辑操作符 条件操作符 逗号表达式 下标引用、函数调用和结构成员 2. 算术操作符 - * / % 注意 /操作符: 对于整型的除法运算结果依然是整数…

十六、代码校验(2)

本章概要 前置条件 断言&#xff08;Assertions&#xff09;Java 断言语法Guava 断言使用断言进行契约式设计检查指令前置条件后置条件不变性放松 DbC 检查或非常严格的 DbCDbC 单元测试 前置条件 前置条件的概念来自于契约式设计(Design By Contract, DbC), 利用断言机制…