MySQL-储存引擎

server/2025/3/12 2:57:45/

目录

MySQL体系结构 

存储引擎简介

InnoDB

介绍

特点

文件

MyISAM

介绍

特点

文件

Memory

介绍

特点

文件

选择

小结


MySQL体系结构 

MySQL的系统体系结构一般来说分为一下几层:

  • 连接层
  • 服务层
  • 引擎层
  • 储存层 

存储引擎简介

存储引擎是储存数据,建立索引,更新/查询数据的实现方式。引擎没有好坏之分,不同的场景应该选择合适的引擎。引擎是基于表的,而不是基于库的,所以也被称为表类型

在创建表时,指定储存引擎类型:

create  table  表名  (

        字段1,字段类型  [ 注释 ]  ,

        字段2,字段类型  [ 注释 ]   

Engine = 储存类型 [ 注释 ] ;

查看当前数据库支持的储存引擎:

show engines;
  • InnoDB

介绍

InnoDB是一种高可靠性和高性能性的储存引擎,自从MySQL 5.5之后,InnoDB就是MySQL的默认储存引擎。

特点

  • DML操作遵循ACID原则
  • 行级锁,提高并发性能
  • 支持外键约束,提高数据的一致性和完整性

文件

xxx.ibd,innnoDB的每张表都有一个对应的表文件,储存表结构,数据和索引。 

逻辑储存结构

MyISAM和Memory

  • MyISAM

介绍

是早期MySQL的默认储存引擎

特点

支持表锁,不支持行锁

访问速度更快

文件

xxx.sdi 储存表结构信息

xxx.MYD 储存数据

xxx.MYI 储存索引

  • Memory

介绍

Memory时储存在内存中的,由于受到硬件影响或者是断电等问题,所以一般储存临时信息、临时表

特点

内存储存

hash索引(默认)

  • 也是表锁

文件

xxx.sdi  储存表结构信息

选择

针对应用系统的选择合适的储存引擎,当然也可以根据实际系统的情况,自由的对储存引擎进行组合

  • InnoDB:是MySQL的默认储存引擎,支持事务,外键。如果对于事物的完整性,并发事务条件下希望保证数据的一致性,除了查询插入操作还有大量删除更新操作,那么InnoDB是最好的选择。
  • MyISAM:一般是大量查询插入操作,少量删除更新操作,并且对于事务的完整性、并发性并没有许多要求,那么这个将会是最好的选择。
  • Memor:储存在内存中,访问速度快,通常用于临时表及缓存。缺点是有表的大小限制,不能存储大量的数据,无法保证数据的安全性。

小结


http://www.ppmy.cn/server/174325.html

相关文章

双击PPT文件界面灰色不可用,需要再次打开该PPT文件才能正常打开

双击PPT文件界面灰色不可用,需要再次打开该PPT文件才能正常打开 1. 软件环境⚙️2. 问题描述🔍3. 解决方法🐡解决步骤 4. 结果预览🤔 1. 软件环境⚙️ Windows10 或 Windows11 专业版64位,安装MotionGo软件&#xff08…

【前端】BOM DOM

两天更新完毕,建议关注收藏点赞 友情链接: HTML&CSS&LESS&Bootstrap&Emmet Axios & AJAX & Fetch BOM DOM 待整理 js2 Web API 是浏览器提供的一套操作浏览器功能和页面元素的 API ( BOM 和 DOM)。官方文档点击跳转 目录 BOMDOM…

再聊 Flutter Riverpod ,注解模式下的 Riverpod 有什么特别之处,还有发展方向

三年前我们通过 《Flutter Riverpod 全面深入解析》 深入理解了 riverpod 的内部实现,而时隔三年之后,如今Riverpod 的主流模式已经是注解,那今天就让我们来聊聊 riverpod 的注解有什么特殊之处。 前言 在此之前,我们需要先回忆…

Nest.js全栈开发终极实践:TypeORM+微服务+Docker构建高可用企业级应用

文章目录 **第一部分:认识Nest.js与基础环境搭建****1.1 什么是Nest.js?****1.2 环境准备****1.3 创建第一个项目****1.4 启动开发服务器****1.5 核心文件解读** **第二部分:基础控制器与路由****2.1 控制器的作用****2.2 创建自定义控制器**…

deepseek为什么要开源

一、生态位的抢占与锁定:以 JDK 版本为例​ 在软件开发的世界里,生态位的抢占和先入为主的效应十分显著。就拿 Java 开发中的 JDK 版本来说,目前大多数开发者仍在广泛使用 JDK8。尽管 JDK17 和 JDK21 已经推出,且具备更多先进特性…

nodejs关于后端服务开发的探究

前提 在当前的环境中关于web server的主流开发基本上都是java、php之类的,其中java spring系列基本上占了大头,而python之流也在奋起直追,但别忘了nodejs也是可以做这个服务的,只是位置有点尴尬,现在就来探究下nodejs…

小迪安全-27-php开发,tp框架,路由访问,对象操作,内置过滤,核心漏洞

下载一个thinkphp的框架 thinkphp就是一个mvc架构 5.0.2即可 绑定一下域名到 就可以访问了 而输出的地方在这里 而这种框架有使用手册和规范操作,代码写法也跟原生不一样,例如数据库配置 只需要在这里输入好即可,都不用自己再去写链接 这是…

代码随想录 回溯

131. 分割回文串 - 力扣(LeetCode) 这题挺难的,搞了两个小时才一知半解吧qaq 思路:首先要明白什么作为终止条件,其次就是for循环内什么时候插入path,剩下的就是套模板了,其次补充一下回文数的…