MYSQL存储引擎基础知识介绍

news2025/2/23 1:43:13

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

在这里插入图片描述

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
环境十分适合。

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

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

相关文章

怒刷LeetCode的第11天(Java版)

目录 第一题 题目来源 题目内容 解决方法 方法一:迭代 方法二:递归 方法三:指针转向 第二题 题目来源 题目内容 解决方法 方法一:快慢指针 方法二:Arrays类的sort方法 方法三:计数器 方法四…

【Java 基础篇】Java线程组详解

Java线程组是一种用于管理线程的机制,它允许你将线程组化为一个单元,并对组内的线程进行一些操作和控制。本文将详细介绍Java线程组的概念、如何创建和管理线程组,以及线程组的一些常见用法。 什么是线程组? 线程组是一个用于组…

python生成PDF报告

前言 最近接到了一个需求-将项目下的样本信息汇总并以PDF的形式展示出来,第一次接到这种PDF的操作的功能,还是有点慌的,还好找到了reportlab这个包,可以定制化向PDF写内容! 让我们由简入深进行讲解 一、reportlab是…

2023年腾讯云轻量服务器测评:16核 32G 28M 配置CPU测试

腾讯云轻量应用服务器16核32G28M配置优惠价3468元15个月(支持免费续3个月/送同配置3个月),轻量应用服务器具有100%CPU性能,系统盘为380GB SSD盘,28M带宽下载速度3584KB/秒,月流量6000GB,折合每天…

由于找不到d3dx9_43.dll,无法继续执行代码要怎么解决

D3DX9_43.dll是一个动态链接库文件,它是DirectX的一个组件,主要用于支持一些旧版本的游戏和软件。当电脑缺少这个文件时,可能会导致这些游戏和软件无法正常运行。例如,一些老游戏可能需要D3DX9_43.dll来支持图形渲染等功能。此外&…

二分类问题的解决利器:逻辑回归算法详解(一)

文章目录 🍋引言🍋逻辑回归的原理🍋逻辑回归的应用场景🍋逻辑回归的实现 🍋引言 逻辑回归是机器学习领域中一种重要的分类算法,它常用于解决二分类问题。无论是垃圾邮件过滤、疾病诊断还是客户流失预测&…

git安装配置教程

目录 git安装配置1. 安装git2. git 配置3.生成ssh key:4. 获取生产的密钥3. gitee或者github添加ssh-key4.git使用5. git 使用-本地仓库与远程仓库建立连接第一步:进入项目文件夹,初始化本地仓库第二步:建立远程仓库。 建立远程连接的小技巧 …

strcpy常见的错误

char* arr "handsome"; strcpy(arr, "pretty"); printf("%s\n", arr); 这个程序在编译器上是运行不出来的,因为arr是一个字符串指针,它的值不可以被修改,可以将arr改成字符数组

录屏没有声音怎么办,3个方法教你解决

随着科技的不断发展,人们越来越依赖电子设备进行工作和学习。在这个过程中,录屏已经成为了一种必要的技能。无论是手机还是电脑,我们都可以通过录屏来记录重要的信息。但是,有时候我们在录屏时会发现声音无法正常录制,…

前后端分离的低代码快速开发框架

低代码开发正逐渐成为企业创新的关键工具。通过提高开发效率、降低成本、增强灵活性以及满足不同用户需求,低代码开发使企业能够快速响应市场需求,提供创新解决方案。选择合适的低代码平台,小成本组建一个专属于你的应用。 项目简介 这是一个…

竞赛 基于深度学习的人脸识别系统

前言 🔥 优质竞赛项目系列,今天要分享的是 基于深度学习的人脸识别系统 该项目较为新颖,适合作为竞赛课题方向,学长非常推荐! 🧿 更多资料, 项目分享: https://gitee.com/dancheng-senior/…

spring security教程(一)--认证

零.简介 【1】简介 【2】登录校验流程 【3】原理(入门的时候先了解一下就好) 一.思路分析 二.建表 确保你已经建立好一张用户表,并且引入springboot,mybatis,mp,slf4j等基础依赖。 即使你有多个角色你也可以将他们的…

安装社区版本OB

获取一键安装包 https://www.oceanbase.com/softwarecenter 离线安装 [admintest001 ~]$ tar -xzf oceanbase-all-in-one-*.tar.gz [admintest001 ~]$ cd oceanbase-all-in-one/bin/ [admintest001 bin]$ ./install.sh [admintest001 bin]$ source ~/.oceanbase-all-in-one/…

【人工智能】企业如何使用 AI与人工智能的定义、研究价值、发展阶段的深刻讨论

前言 人工智能(Artificial Intelligence),英文缩写为AI。 它是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。人工智能是新一轮科技革命和产业变革的重要驱动力量。 📕作者简介&#x…

stm32学习-芯片系列/选型/开发方式

【03】STM32HAL库开发-初识STM32 | STM概念、芯片分类、命名规则、选型 | STM32原理图设计、看数据手册、最小系统的组成 、STM32IO分配_小浪宝宝的博客-CSDN博客  STM32:ST是意法半导体,M是MCU/MPU,32是32位。  ST累计推出了&#xff1a…

【NCRE 二级Java语言程序设计03】考试环境及考试过程概览

目录 前言一、考试环境介绍1.硬件环境2.软件环境 二、考试特别说明1.考试时间说明2.考试题型及分值 三、考试流程介绍1.登录考试系统2.考试答题界面3.答题交卷操作 总结 前言 📜本专栏主要是分享自己备考全国计算机二级Java语言程序设计所学心得体会、所搜集的资料信…

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

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

大数据快速入门开发环境篇:CentOS 7安装配置Hadoop大数据框架开发环境

注意:在开始安装之前,请确保您的CentOS 7系统已经正确安装和配置了Java。Hadoop需要Java来运行。 目录 一、下载与配置Hadoop框架:1.1、下载与环境变量设置1.2、XML配置文件Hadoop设置1.3、格式化HDFS 二、Hadoop 3.x版本中hdfs命令的问题解…

使用命令行(CMD)编译单Java文件

1.安装JDK JDK官网:https://www.oracle.com/java/technologies/downloads/ 选 Windows -> x64 MSI Instaler或者x64 Installer 安装成功后。 2.配置环境变量 按下Win键,搜索环境变量 添加JAVA_HOME系统环境变量,要指定类似这样的路径(…

day1_QT

day1_QT 实现登录窗口效果 实现登录窗口 #include "loginwindow.h"LoginWindow::LoginWindow(QWidget *parent): QWidget(parent) {//设置窗口标题和图标this->setWindowTitle("ChatWe");this->setWindowIcon(QIcon("D:\\learn\\QT\\day1\\wor…