当前位置: 首页 > news >正文

MYSQL存储引擎基础知识介绍

下面重点介绍几种常用的存储引擎,并对比各个存储引擎之间的区别,以帮助读者理解
不同存储引擎的使用方式。

在这里插入图片描述

MyISAM

  1. MyISAM是 MySQL的默认存储引擎。MyISAM不支持事务、也不支持外键,其优势是访
    问的速度快,对事务完整性没有要求或者以 SELECT、INSERT 为主的应用基本上都可以使用
    这个引擎来创建表。
  2. 每个 MyISAM在磁盘上存储成 3个文件,其文件名都和表名相同,但扩展名分别是:
    .frm(存储表定义);
    .MYD(MYData,存储数据);
    .MYI (MYIndex,存储索引)。
    数据文件和索引文件可以放置在不同的目录,平均分布 IO,获得更快的速度。
  3. 要指定索引文件和数据文件的路径,需要在创建表的时候通过 DATA DIRECTORY和 INDEX
    DIRECTORY语句指定,也就是说不同 MyISAM表的索引文件和数据文件可以放置到不同的路
    径下。文件路径需要是绝对路径,并且具有访问权限。
  4. 要指定索引文件和数据文件的路径,需要在创建表的时候通过 DATA DIRECTORY和 INDEX
    DIRECTORY语句指定,也就是说不同 MyISAM表的索引文件和数据文件可以放置到不同的路
    径下。文件路径需要是绝对路径,并且具有访问权限。
  5. MyISAM类型的表可能会损坏,原因可能是多种多样的,损坏后的表可能不能访问,会
    提示需要修复或者访问后返回错误的结果。MyISAM类型的表提供修复的工具,可以用 CHECK
    TABLE语句来检查 MyISAM表的健康,并用 REPAIR TABLE语句修复一个损坏的 MyISAM表。
    表损坏可能导致数据库异常重新启动,需要尽快修复并尽可能地确认损坏的原因。

InnoDB

  1. InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比 MyISAM
    的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。
  2. 对于 InnoDB表,自动增长列必须是索引。如果是组合索引,也必须是组合索引的第一
    列,但是对于 MyISAM表,自动增长列可以是组合索引的其他列,这样插入记录后,自动增
    长列是按照组合索引的前面几列进行排序后递增的。
  3. 外键约束:MySQL 支持外键的存储引擎只有 InnoDB,在创建外键的时候,要求父表必须有对应的
    索引,子表在创建外键的时候也会自动创建对应的索引。
  4. 在创建索引的时候,可以指定在删除、更新父表时,对子表进行的相应操作,包 RESTRICT、
    CASCADE、SET NULL和 NO ACTION。其中 RESTRICT和 NO ACTION相同,是指限制在子表有
    关联记录的情况下父表不能更新;CASCADE表示父表在更新或者删除时,更新或者删除子表
    对应记录;SET NULL则表示父表在更新或者删除的时候,子表的对应字段被 SET NULL。选
    择后两种方式的时候要谨慎,可能会因为错误的操作导致数据的丢失。
  5. 当某个表被其他表创建了外键参照,那么该表的对应索引或者主键禁止被删除。
    在导入多个表的数据时,如果需要忽略表之前的导入顺序,可以暂时关闭外键的检查;
    同样,在执行 LOAD DATA和 ALTER TABLE操作的时候,可以通过暂时关闭外键约束来加快处
    理的速度,关闭的命令是“SET FOREIGN_KEY_CHECKS = 0;”,执行完成之后,通过执行“SET
    FOREIGN_KEY_CHECKS = 1;”语句改回原状态。
  6. 对于 InnoDB类型的表,外键的信息通过使用 show create table或者 show table status命
    令都可以显示。

MEMORY

  1. MEMORY存储引擎使用存在内存中的内容来创建表。每个 MEMORY表只实际对应一个
    磁盘文件,格式是.frm。MEMORY 类型的表访问非常得快,因为它的数据是放在内存中的,
    并且默认使用 HASH索引,但是一旦服务关闭,表中的数据就会丢失掉。
  2. 在启动 MySQL服务的时候使用–init-file选项,把 INSERT INTO … SELECT或 LOAD DATA
    INFILE这样的语句放入这个文件中,就可以在服务启动时从持久稳固的数据源装载表。
  3. 服务器需要足够内存来维持所有在同一时间使用的 MEMORY表,当不再需要 MEMORY
    表的内容之时,要释放被 MEMORY表使用的内存,应该执行 DELETE FROM或 TRUNCATE TABLE,或者整个地删除表(使用 DROP TABLE操作)。
  4. 每个 MEMORY表中可以放置的数据量的大小,受到 max_heap_table_size系统变量的约
    束,这个系统变量的初始值是 16MB,可以按照需要加大。此外,在定义 MEMORY表的时候,
    可以通过 MAX_ROWS子句指定表的最大行数。
    5.MEMORY 类型的存储引擎主要用在那些内容变化不频繁的代码表,或者作为统计操作
    的中间结果表,便于高效地对中间结果进行分析并得到最终的统计结果。对 MEMORY 存储
    引擎的表进行更新操作要谨慎,因为数据并没有实际写入到磁盘中,所以一定要对下次重新
    启动服务后如何获得这些修改后的数据有所考虑。

MERGE

  1. MERGE存储引擎是一组 MyISAM表的组合,这些 MyISAM表必须结构完全相同,MERGE
    表本身并没有数据,对 MERGE类型的表可以进行查询、更新、删除的操作,这些操作实际
    上是对内部的实际的 MyISAM 表进行的。对于 MERGE 类型表的插入操作,是通过
    INSERT_METHOD子句定义插入的表,可以有 3个不同的值,使用 FIRST或 LAST值使得插入
    操作被相应地作用在第一或最后一个表上,不定义这个子句或者定义为 NO,表示不能对这
    个 MERGE表执行插入操作。
  2. 可以对 MERGE表进行 DROP操作,这个操作只是删除 MERGE的定义,对内部的表没有
    任何的影响。
    MERGE表在磁盘上保留两个文件,文件名以表的名字开始,一个.frm文件存储表定义,
    另一个.MRG文件包含组合表的信息,包括 MERGE表由哪些表组成、插入新的数据时的依据。
    可以通过修改.MRG文件来修改 MERGE表,但是修改后要通过 FLUSH TABLES刷新。
  3. MERGE表并不能智能地将记录写到对应的表中,而分区
    表是可以的(分区功能在 5.1版中正式推出)。通常我们使用 MERGE表来透明地对多个表进
    行查询和更新操作,而对这种按照时间记录的操作日志表则可以透明地进行插入操作。

如何选择合适的存储引擎

在选择存储引擎时,应根据应用特点选择合适的存储引擎,对于复杂的应用系统可以根
据实际情况选择多种存储引擎进行组合。
下面是常用存储引擎的适用环境。
MyISAM:默认的 MySQL 插件式存储引擎。如果应用是以读操作和插入操作为主,
121
只有很少的更新和删除操作,并且对事务的完整性、并发性要求不是很高,那么选择这个存
储引擎是非常适合的。MyISAM是在 Web、数据仓储和其他应用环境下最常使用的存储引擎
之一。
InnoDB:用于事务处理应用程序,支持外键。如果应用对事务的完整性有比较高的
要求,在并发条件下要求数据的一致性,数据操作除了插入和查询以外,还包括很多的更新、
删除操作,那么 InnoDB存储引擎应该是比较合适的选择。InnoDB存储引擎除了有效地降低
由于删除和更新导致的锁定,还可以确保事务的完整提交( Commit)和回滚(Rollback),
对于类似计费系统或者财务系统等对数据准确性要求比较高的系统,InnoDB 都是合适的选
择。
MEMORY:将所有数据保存在 RAM中,在需要快速定位记录和其他类似数据的环境
下,可提供极快的访问。MEMORY 的缺陷是对表的大小有限制,太大的表无法 CACHE 在内
存中,其次是要确保表的数据可以恢复,数据库异常终止后表中的数据是可以恢复的。
MEMORY表通常用于更新不太频繁的小表,用以快速得到访问结果。
MERGE:用于将一系列等同的 MyISAM表以逻辑方式组合在一起,并作为一个对象
引用它们。MERGE 表的优点在于可以突破对单个 MyISAM 表大小的限制,并且通过将不同
的表分布在多个磁盘上,可以有效地改善 MERGE表的访问效率。这对于诸如数据仓储等 VLDB
环境十分适合。

相关文章:

MYSQL存储引擎基础知识介绍

下面重点介绍几种常用的存储引擎,并对比各个存储引擎之间的区别,以帮助读者理解 不同存储引擎的使用方式。 MyISAM MyISAM是 MySQL的默认存储引擎。MyISAM不支持事务、也不支持外键,其优势是访 问的速度快,对事务完整性没有要求或者以 SEL…...

vue学习之element-ui组件集成

1. element-ui 链接 https://element.eleme.cn/#/zh-CN 2. element-ui 安装 cnpm install element-ui3. 创建项目 https://blog.csdn.net/qq_36940806/article/details/132921688?spm=1001.2014.3001.5502 4. 引入element库 /src/main.js 引入 element-uiimport Vue from…...

如何通过百度SEO优化提升网站排名(掌握基础概念,实现有效优化)

随着互联网的发展,搜索引擎优化(SEO)成为了网站优化中不可或缺的一部分。在中国,百度搜索引擎占据着主导地位,因此掌握百度SEO概念和优化技巧对网站的排名和曝光非常重要。 百度SEO排名的6个有效方法: 首…...

Golang 字符串

目录 1. Golang 字符串1.1. 基础概念1.2. 字符串编码1.3. 遍历字符串1.4. 类型转换1.5. 总结1.6. String Concatenation (字符串连接)1.6.1. Using the operator1.6.2. Using the operator1.6.3. Using the Join method1.6.4. Using Sprintf method1.6.5. Using Go string Bu…...

python应用中使用了multiprocessing多进程,使用pyinstaller打包出来的程序可能产生多个窗口

问题现象 我用pyside(类似pyqt)开发了一个应用程序。直接使用pycharm运行,一切都正常。但当我使用pyinstaller将它打包之后,再去运运行,发现窗口总是产生多个。 问题分析 直接运行没有问题,那么问题肯定…...

数据结构与算法——13.队列的拓展

这篇文章主要讲一下双端队列,优先队列,阻塞队列等队列的拓展内容。 目录 1.队列拓展概述 2.双端队列的链表实现 3.双端队列的数组实现 4.优先队列无序数组实现 5.阻塞队列 6.总结 1.队列拓展概述 首先来看一张图,来大致了解一下他们的…...

机器学习入门教学——损失函数(交叉熵法)

1、前言 我们在训练神经网络时,最常用到的方法就是梯度下降法。在了解梯度下降法前,我们需要了解什么是损失(代价)函数。所谓求的梯度,就是损失函数的梯度。如果不知道什么是梯度下降的,可以看一下这篇文章:机器学习入…...

pytest一些常见的插件

Pytest拥有丰富的插件架构,超过800个以上的外部插件和活跃的社区,在PyPI项目中以“ pytest- *”为标识。 本篇将列举github标星超过两百的一些插件进行实战演示。 插件库地址:http://plugincompat.herokuapp.com/ 1、pytest-html&#xff1…...

基于51单片机多路DTH11温湿度检测控制系统

一、系统方案 1、本设计采用51单片机作为主控器。 2、DHT11采集温度度,支持3路温度度,液晶1602显示。 3、按键设置报警阀值。 4、系统声光报警。 二、硬件设计 原理图如下: 三、单片机软件设计 1、首先是系统初始化 //初始化LCD*********…...

宝塔重装注意事项

欢迎关注我的公众号:夜说猫,让一个贫穷的程序员不靠打代码也能吃饭~ 前言 宝塔8.0版本,宝塔卸载重装,或者重装Linux系统后重新安装宝塔也适用。 不能上来直接就执行安装宝塔脚本,除非之前没有安装过宝塔。 步骤 1、…...

【MySQL】 MySQL的增删改查(进阶)--壹

文章目录 🛫数据库约束🌴约束类型🎋NOT NULL约束🎍UNIQUE:唯一约束🌳DEFAULT:默认值约束🎄PRIMARY KEY:主键约束🍀FOREIGN KEY:外键约束&#x1f…...

Map<K,V>的使用和List学习

Map Map是一种专门用来进行搜索的容器或者数据结构,其搜索的效率与其具体的实例化子类有关。对于静态类型的查找来说,一般直接遍历或者用二分查找【不会对区间进行插入和删除操作】 而在现实生活中的查找比如: 根据姓名查询考试成绩通讯录…...

Flask实现Web服务调用Python程序

Flask实现Web服务调用Python程序_flask调用python程序_小白白程序员的博客-CSDN博客 【小沐学Python】Python实现Web服务器(Flask入门)_python flask web开发_爱看书的小沐的博客-CSDN博客...

步步为营,如何将GOlang引用库的安全漏洞修干净

文章目录 引场景构建第一步、直接引用的第三方库升级修复策略1.确认是否为直接引用的第三方库2.找到需要升级的版本是否为release版本 第二步、间接引用的第三方库升级修复策略那么问题来了,我们这么间接引用库的对应的直接引用库是哪个呢? (…...

as-if-serial与happens-before原则详解

文章目录 前言详解解决多线程下的问题 Happens-before原则总结as-if-serial语义happens-before的例子 前言 "as-if-serial"原则是Java内存模型中的一个重要概念。该规则规定:不管怎么重排序(编译期间的重排序,指令级并行的重排序&…...

基于Yolov8的工业小目标缺陷检测(2):动态蛇形卷积(Dynamic Snake Convolution),实现暴力涨点 | ICCV2023

目录 1.工业油污数据集介绍 1.1 小目标定义 1.2 难点 1.3 工业缺陷检测算法介绍 1.3.1 YOLOv8...

ARM64汇编基础

ARM64汇编基础 主要内容 到目前为止,大部分的移动设备都是64位的arm架构,一直想抽个时间系统学习下,这个周末就专门来学习下。毕竟两天的时间,也只是简单的入门了解下,为后续工作和学习打下基础。 本次学习的主要内容…...

Nodejs 第十六章(ffmpeg)

FFmpeg 是一个开源的跨平台多媒体处理工具,可以用于处理音频、视频和多媒体流。它提供了一组强大的命令行工具和库,可以进行视频转码、视频剪辑、音频提取、音视频合并、流媒体传输等操作。 FFmpeg 的主要功能和特性: 格式转换:…...

k8s集群部署es

集群内创建需要用到存储,此处举例使用腾讯云cfs共享存储 内存limits限制不需要加,否则会经常内存溢出导致es集群故障 apiVersion: apps/v1 kind: StatefulSet metadata:name: es7-clusternamespace: elasticsearch spec:serviceName: es-clusterreplica…...

学习记忆——宫殿篇——记忆宫殿——记忆桩——火车+外院+客厅+卧室

护板 警示灯 烟筒 采集箱 司炉室 桥 电线杆 棚顶 车厢 护栏 植物 石阶 水泥台 竹门 树干 躺椅 柱子 墙 池 洞 方灯 枕头 树 浴池 墙 射灯 藤条 浴巾框 耳环 窗户 灯 沙发 壁炉 吊灯 兵马俑 门 石佛 沙发椅 圆木 弧形木箱盖 床 窗帘 画板 纸伞 花 沙发背 颜料 抽屉...

QT用户登录注册,数据库实现

登录窗口头文件 #ifndef LOGINUI_H #define LOGINUI_H#include <QWidget> #include <QLineEdit> #include <QPushButton> #include <QLabel> #include <QMessageBox>#include <QSqlDatabase> //数据库管理类 #include <QSqlQuery> …...

GEE学习总结(9)——像元二分法计算月度植被覆盖度(MODIS)

像元二分法计算植被覆盖度 通过MODIS的NDVI数据集MOD13Q1和像元二分法计算植被覆盖度 var multi_NDVI ee.ImageCollection(MODIS/006/MOD13Q1).filterDate(2015-06-01, 2016-09-01).select(NDVI).max().divide(10000).clip(geometry);var ndviVis {min: 0.0,max: 1,palette…...

RabbitMQ用户命令_策略_日志

RabbitMQ相关安装 Centos离线安装RabbitMQ并开启MQTT Docker安装rabbitMQ RabbitMQ集群搭建和测试总结_亲测 Docker安装RabbitMQ集群_亲测成功 RabbitMQ创建管理员命令 #查看当前用户命令&#xff1a; rabbitmqctl list_users#创建用户和密码 rabbitmqctl add_user admin…...

停车场系统、智慧城市停车、智慧社区、物业管理、新能源充电、人脸门禁 uniapp 系统源码

1. 智慧停车 支持模式 封闭性单个停车场路边停车(车位级管理)大小场(场中场)&#xff0c;多场子并行或嵌套 所有者模式 统一平台管理总平台下子账号(区域代理)自建场地资源&#xff0c;自行维护数据总平台下子账号(区域代理)再分配和单个停车场管理人员(物业管理/维保/保安/财务…...

Linux磁盘管理

物理设备的命名规则 在linux系统中一切都是文件&#xff0c;硬件设备也不例外。即然是文件&#xff0c;就必须有文件名称。系统内核中的udev设备管理器会自动把硬件名称规范起来&#xff0c;目的是让用户通过设备文件的名字可以看出设备大致的属性以及分区信息等&#xff1b;在…...

vue学习之vue cli创建项目

安装 node.js https://nodejs.org/en 安装 vue cli npm install -g @vue/cli --registry=https://registry.npm.taobao.org创建项目 执行创建命令,回车vue create vue-cli-learning选择 “Manually select features”,回车 “空格” 关闭 Linter / Formatter 选项,回车...

K8S:Pod容器中的存储方式及PV、PVC

文章目录 Pod容器中的存储方式一&#xff0e;emptyDir存储卷1.emptyDir存储卷概念2.emptyDir存储卷示例 二.hostPath存储卷1.hostPath存储卷概念2.hostPath存储卷示例 三.nfs共享存储卷1.nfs共享存储卷示例 四.PV和PVC1.PV、PVC概念2.PVC 的使用逻辑及数据流向3.storageclass插…...

uni-app跳转到另一个app

第一步&#xff1a; 首先要知道 app的包名 获取方式如下 第二步&#xff1a; 在第一个 demo1 app 一个页面中需要一个按钮去跳转 方法如下 <template><view class"content"><button click"tz">跳转</button></view> </…...

如何通过一键导出导入数据实现批量重命名文件名称

在日常办公中&#xff0c;我们经常需要对大量的文件进行重命名&#xff0c;以便更好地管理和查找文件。而且&#xff0c;有时候我们还需要将文件名称翻译成其他语言&#xff0c;以适应不同的工作需求。如何高效地完成这项任务呢&#xff1f;接下来&#xff0c;我将介绍一种方法…...

CTF —— 网络安全大赛(这不比王者好玩吗?)

前言 随着大数据、人工智能的发展&#xff0c;人们步入了新的时代&#xff0c;逐渐走上科技的巅峰。 \ ⚔科技是一把双刃剑&#xff0c;网络安全不容忽视&#xff0c;人们的隐私在大数据面前暴露无遗&#xff0c;账户被盗、资金损失、网络诈骗、隐私泄露&#xff0c;种种迹象…...

php做视频分享网站/保定网站建设报价

node.js版本问题,对某些语句不支持 这不是错误&#xff0c;你可以不用管 继续下一步即可...

苏州做网站建设公司/最新的全国疫情

一、HTTP的缺点 到目前为止&#xff0c;我们已经介绍完HTTP&#xff0c;它具有相当优秀和方便的一面&#xff0c;但它也有不足之处&#xff0c;HTTP 主要有这些不足&#xff0c;例举如下。 通信使用明文&#xff08;不加密&#xff09;&#xff0c;内容可能会被窃听 不验证通…...

查看wordpress版本/百度竞价开户

能坚持别人不能坚持的&#xff0c;才能拥有别人未曾拥有的。 关注编程大道公众号&#xff0c;让我们一同坚持心中所想&#xff0c;一起成长&#xff01;&#xff01; 《【面试突击】— Redis篇》-- Redis的线程模型了解吗&#xff1f;为啥单线程效率还这么高&#xff1f; 原文…...

天津建设监理协会网站/北京做网络优化的公司

&#xff08;图中显示图片的 Item 是在Header、Foot View中的&#xff09; 最近有一个需求&#xff0c; 需要在ListView 的 HeaderView中 添加多个View&#xff0c; 最后发现每个View中都有一条分割线。 效果如图中第一张图片&#xff01; 本来以为只要设置android:headerDivi…...

wordpress twenty thirteen/惠州seo推广优化

74HC595驱动4位7段数码管 1、74HC595介绍 74HCT595 是一个 8 位串行输入/串行或并行输出移位寄存器,带有一个存储寄存器和三态输出。移位寄存器和存储寄存器都有独立的时钟。该器件具有串行输入 (DS) 和串行输出 (Q7S) 以启用级联和异步复位 MR 输入。 MR 上的低电平将复位移…...

wordpress欢迎主题/seo客服

世界那么大&#xff0c;谢谢你来看我&#xff01;&#xff01;关注我你就是个网络、电脑、手机小达人应该很多人都有遇到过这样的问题&#xff0c;就是将U盘插入自己电脑的时候没反应&#xff0c;也不会在磁盘内显示盘符&#xff0c;但是将U盘插入别人的电脑里面可以打开&#…...