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

MySQL-储存引擎

目录

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.kler.cn/a/582213.html

相关文章:

  • 深度解析:如何在 Vue 3 中安全访问子组件实例
  • 使用STM32CubeMX配置定时器中断实现LED每秒闪烁一次(STM32G070CBT6)
  • windows上传uniapp打包的ipa文件到app store构建版本
  • Selenium 中 ActionChains 支持的鼠标和键盘操作设置及最佳实践
  • 密码学系列 - 利用CPU指令加速
  • 高效自动化测试:打造Python+Requests+Pytest+Allure+YAML的接口测试框架
  • 鸿蒙NEXT开发-自定义相机拍照
  • 小程序 wxml 语法 —— 42 条件渲染
  • JavaScript 模块 vs C# 类:封装逻辑的两种哲学
  • 【社交+陪玩服务】全场景陪玩系统源码 小程序+H5双端 社群互动+即时点单+搭建教程
  • Linux 进程信息查看
  • 【每日学点HarmonyOS Next知识】防止重复点击、对话框收拾拦截、自定义键盘焦点、页面层级、自定义对话框创建
  • 【二分算法】-- x的平⽅根(easy)
  • MySQL(第3周)-database命令
  • SVN 拉取,文件冲突 解决办法
  • ruoyi-vue创建一个学生管理系统(CRUD)
  • 使用 OpenSSL 和 Python 实现 AES-256-CBC 加密与解密(安全密钥管理)
  • Spring Boot 与 Spring MVC 有何不同
  • f QT测试
  • 微服务的认识与拆分