【MySQL进阶】--- 存储引擎的介绍

个人主页:兜里有颗棉花糖
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创
收录于专栏【MySQL学习专栏】🎈
本专栏旨在分享学习MySQL的一点学习心得,欢迎大家在评论区讨论💌
在这里插入图片描述

目录

  • 一、什么是存储引擎
  • 二、InnoDB
  • 三、MyISAM
  • 四、Memory
  • 五、存储引擎选择

一、什么是存储引擎

概念:存储引擎作为MySQL中的核心部分,它是MySQL数据库中建立索引、更新/查询数据等技术的实现方式(不同的存储引擎建立索引、更新/查询数据的机制是不同的)。另外,存储引擎是基于数据库表的而不是基于数据库的,即一个数据库的多张表是可以选择不同存储引擎的,故存储引擎也被称之为表类型

我们通过建表语句来看一下存储引擎:
在这里插入图片描述

创建表的时候,我们是可以指定存储引擎的,如果不指定的话,默认的存储引擎就是InnoDB。

语法1:创建表时,要指定存储引擎,语法格式如下:

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

语法2:查看当前数据库支持的存储引擎
语法格式show engines;
执行结果如下:
在这里插入图片描述

二、InnoDB

概念:InnoDB时一种兼顾高可靠性和高性能的通用存储引擎,在MySQL5.5之后,InnoDB是默认的MySQL存储引擎。

InnoDB特点:

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

文件:
xxx.ibdxxx代表的是表名,InnoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frmsdi)、数据和索引。
参数:innodb_file_per_table

当启用该选项时,InnoDB会为数据库中的每个表创建单独的表空间文件。每个表都存储在自己的.ibd文件中,而不是存储在共享的系统表空间中。

输入命令:show variables like 'innodb_file_per_table';
结果演示:
在这里插入图片描述

在这里插入图片描述

我们来看一下idb文件中存放着什么,请看:
在这里插入图片描述

InnoDB中的逻辑存储结构如下:

  • TableSpace:表空间
  • Seqment:段
  • Extent:区
  • Page:页
  • Row:行
    在这里插入图片描述

三、MyISAM

MyISAM是MySQL中早期的默认存储引擎。

MyISAM特点:

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

MyISAM存储引擎表在磁盘中所涉及到的文件有三个,请看:
在这里插入图片描述

  • sdi文件存储的是表结构的信息。
  • myd文件存储的是表中的数据。
  • myi文件存储的是索引。

四、Memory

Memory存储引擎的表数据是存储在内容中的,所以会受到硬件问题、或者断电的影响,所以只能将这些表作为临时表或者缓存使用。

特点:

  • 内存存放
  • hash索引(默认)

文件:

  • xxx.sid:存储表结构信息
  • 没有索引文件和数据文件,因为数据都存放在内存中。

在这里插入图片描述

五、存储引擎选择

我们在选择存储引擎时,应该根据应用系统的特点选择合适的存储引擎。对于复杂的应用系统,还可以根据实际情况选择多种存储引擎进行组合。

  • InnoDB:是MySQL中默认的存储引擎,支持事务、外键。如果应用对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包括很多的更新、删除操作,这时我们选择InnoDB存储引擎比较合适。
  • MyISAM:如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性、并发性要求不是很高,那么选择MySIAM存储引擎是很合适的。比如日志、评论等。
  • MEMORY:将所以的数据保存在内存中,访问速度快,通常用于临时表以及缓存。MEMORY的缺陷就是对表的大小有限制,太大的表无法存储在内存中(注意内存和磁盘是有所区别的,磁盘中存储几个G的数据完全可以,但是如果让内存中存储几个G的数据的代价是很大的),而且无法保障数据的安全。

好了,以上就是本文的全部内容了,就到这里吧,再见啦友友们!!!

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

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

相关文章

ALOS2 PALSAR2 数据ID命名规则

场景ID AAAAABBBBBCCCC-YYMMDD AAAAA:卫星类别“ALOS2” BBBBB:以场景为中心的总计循环号码 CCCC:场景中心的帧编号 -: 分隔号 YYMMDD:场景中心的观测年月日 (YY:末两位年,MM:月,DD:日) 产品ID DDDEFFFGHI DDD:观测模式 SBS:聚光灯模式 UBS:高分辨…

HMTL知识点系列(3)

目录 1. 如何在HTML中嵌入视频和音频?2. 解释一下HTML的“盒模型”是什么,以及它如何影响布局?3. 你如何理解HTML的语义化标签和SEO优化之间的关系?4. 什么是HTML5的canvas元素,你如何使用它来创建图形?5. …

【k8s】【docker】web项目的部署

yaml配置文件 后端:springboot项目 前端:vue项目,之前镜像封装的nginx.conf反向代理配置直接使用了docker-compose.yml中services的名称,无法代理成功,可修改为127.0.0.1 # 后端 apiVersion: apps/v1 kind: Deployment…

Object.defineProperty()方法详解,了解vue2的数据代理

假期第一篇,对于基础的知识点,我感觉自己还是很薄弱的。 趁着假期,再去复习一遍 Object.defineProperty(),对于这个方法,更多的还是停留在面试的时候,面试官问你vue2和vue3区别的时候,不免要提一提这个方法…

(2023,ControlNet,CFGRW,diffusion,控制组合)向文本到图像扩散模型添加条件控制

Adding Conditional Control to Text-to-Image Diffusion Models 公众号:EDPJ(添加 VX:CV_EDPJ 或直接进 Q 交流群:922230617 获取资料) 目录 0. 摘要 1. 简介 2.相关工作 2.1. 微调神经网络 2.2. 图像扩散 …

git是什么,git常用命令

Git是一种分布式版本控制系统,最初由Linus Torvalds创作并用于管理Linux内核代码。 常见的一些Git命令包括: git init:初始化一个新的Git仓库;git add:将文件添加到Git仓库中;git commit:将更…

FFmpeg 命令:从入门到精通 | ffmpeg 命令分类查询

FFmpeg 命令:从入门到精通 | ffmpeg 命令分类查询 FFmpeg 命令:从入门到精通 | ffmpeg 命令分类查询ffmpeg -versionffmpeg -buildconfffmpeg -formatsffmpeg -muxersffmpeg -demuxersffmpeg -codecsffmpeg -decodersffmpeg -encodersffmpeg -bsfsffmpeg…

基于SSM+Vue的医院住院综合服务管理系统的设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用Vue技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

Axios有哪些常用的方法?

Axios是一个常用的JavaScript库,用于进行HTTP请求。它提供了一组简洁而强大的方法来发送各种类型的请求,并处理响应数据。以下是Axios中一些常用的方法及其格式: GET请求: axios.get(url[, config]).then(response > {// 请求…

三、2023.9.29.C++面向对象.3

文章目录 33、简述一下什么是面向对象?34、简述一下面向对象的三大特征?35、简述一下 C 的重载和重写,以及它们的区别?36、说说 C 的重载和重写是如何实现的?37、说说构造函数有几种,分别什么作用?38、只定…

汽车电子——产品标准规范汇总和梳理(开发体系)

文章目录 前言 一、设计架构 二、安全可靠 三、测试验证 四、过程能力 五、质量管理 六、开发指南 总结 前言 见《汽车电子——产品标准规范汇总和梳理》 一、设计架构 《Autosar R22-11 汽车开放系统体系架构》 二、安全可靠 《GB/T 34590.1-2022(ISO 262…

信息学奥赛一本通 2075:【21CSPJ普及组】插入排序(sort) | 洛谷 P7910 [CSP-J 2021] 插入排序

【题目链接】 ybt 2075&#xff1a;【21CSPJ普及组】插入排序&#xff08;sort&#xff09; 洛谷 P7910 [CSP-J 2021] 插入排序 【题目考点】 1. 排序&#xff1a; 插入排序 插入排序示例&#xff1a; #include <bits/stdc.h> using namespace std; int main() {int…

leetcode201 Bitwise AND of Numbers Range

求区间内的数字全部与之后的结果 其实可以观察到&#xff0c;只会留下从高到低&#xff0c;第一个不同位之前的 12 ---- 110011 ---- 101110 ---- 10109 ---- 10018 ---- 10007 ---- 01116 ---- 01105 ---- 0101像这种一位都不会相同 因此代码可以直接删除最低位的1&…

表格内日期比较计算

需求&#xff1a;在表格中新增数据&#xff0c;计算开始日期中最早的和结束日期中最晚的&#xff0c;回显到下方。 <el-formref"formRef":model"ruleForm":rules"rules"style"margin-top: 20px;"label-position"top">…

博弈论——斯塔克尔伯格模型(Stackelberg model)

斯塔克尔伯格模型(Stackelberg model) 0 前言 前两篇文章中我们提到了连续产量的古诺模型以及可以应用于古诺模型的反应函数。 博弈论——连续产量古诺模型 博弈论——反应函数 古诺模型中&#xff0c;我们强调了: &#xff08;1&#xff09;两个厂商是同时决策的,即博弈只有…

cargo 使用国内的镜像

打开或新建 ~/.cargo/config 文件 vim ~/.cargo/config修改为 中国科学技术大学镜像服务器 [source.crates-io] registry "https://github.com/rust-lang/crates.io-index" replace-with ustc [source.ustc] registry "git://mirrors.ustc.edu.cn/crates.i…

python爬虫基于管道持久化存储操作

文章目录 基于管道持久化存储操作scrapy的使用步骤1.先转到想创建工程的目录下&#xff1a;cd ...2.创建一个工程3.创建之后要转到工程目录下4.在spiders子目录中创建一个爬虫文件5.执行工程setting文件中的参数 基于管道持久化存储的步骤&#xff1a;持久化存储1&#xff1a;保…

IntelliJ IDEA 常用快捷键一览表

目录 1-IDEA的日常快捷键 第1组&#xff1a;通用型 第2组&#xff1a;提高编写速度&#xff08;上&#xff09; 第3组&#xff1a;提高编写速度&#xff08;下&#xff09; 第4组&#xff1a;类结构、查找和查看源码 第5组&#xff1a;查找、替换与关闭 第6组&#xff1a…

JavaScript关于==隐式转换的判断

一.以下数据类型转布尔值&#xff0c;以下均返回true&#xff1a; 1. 非空字符串 2. 非零数值 3. 数组 4. 对象 5. 函数 二.判断方法: 1. 前提条件: 1) 相等操作符&#xff0c;不同数据类型会根据一定规则转换为同一数据类型再比较 注意: (这里指的数据类型也可能需要转…

Win11下无法打开丛林之狐,提示未检测到DirectX 8.1

新装的win11系统&#xff0c;打开丛林之狐提示未检测到DirectX 8.1. 运行dxdiag检查DirectX版本&#xff1a; DX版本已经是12了&#xff1a; 最终参考了这篇文章解决了&#xff1a; 罪恶都市出现XX-directx version 8.1处理方法 - 知乎 控制面板 > 程序 > 启用或关闭Wi…