mysql数据库存储逻辑_MySQL逻辑架构及存储引擎简介

2023-11-01

MySQL逻辑架构:

并发控制:由锁实现

读锁:也叫共享锁,读锁互相不阻塞。A加锁表后A,b,c,d都能读该表但不能写该表。

写锁:也叫排他锁,写锁相互阻塞。A加排他锁后,其他线程不能读写该表。

锁粒度:

表锁:锁一个表,并发粒度小。代表存储引擎MyISAM

行锁:锁一行数据,并发粒度大,并发操作表性能好。代表存储引擎InnoDB。锁粒度小系统对锁的开销也大。

假如给一个表加读锁,那么其他线程也无法对该表进行写操作了,如果是加行锁那么该线程只阻塞只对这一行数据的读写,表中其他行的数据其他线程可以读写,提高并发性能。

事务:相当于把N条语句打包成一条语句,这个包中的N条语句全部执行成功则成功,如果有其中一条语句没有执行成功则事务回滚到原先状态事务执行失败不写入硬盘。

ACID(atomicityconsistency isolation durability)原子性,一致性,隔离性,持久性。是事务存储引擎的特性。

原子性:事务相当于一个N条语句的包,要么全部执行成功,要么则失败,对于事务来说不能成功执行一个事务的一部分,这就是原子性。

一致性:从一个一致的状态转换到另一个一致的状态。要么成功转换为成功的状态,要么失败回滚为原来的状态。

隔离性:A事务看不到B事务。

持久性:事务执行成功则写入硬盘,这就是叫持久性。

存储引擎:

·数据库存在目录中,库中的表存在该目录下。

·查看存储引擎:show table status like ‘table_name’ \G;

MyISAM存储引擎

·将表存在3个文件中.MYD存数据.MYI存索引.frm存表定义。

·支持表锁

·myisam表很大时更容易出现故障,需要手工进行修复表,并且修复时间会非常漫长。修复表步骤:检查表,然后修复表。

·压缩表

InnoDB

·将表存在2个文件中ibdata1数据文件和数据库目录下的.frm表定义文件。

·支持事务

·支持行锁

·外键约束

·基于聚簇索引建立的,聚簇索引对主键查询性能非常高。

·InnoDB支持热备份,而其他所有存储引擎都不支持热备份。

选择合适的存储引擎:

·MySQL5.5默认存储引引擎为InnoDB,最简单的答案是如果你不知道该选用何种存储引擎那么你就用InnoDB,因为它支持事务并且性能好。有些人说MyISAM性能比InnoDB快,这可不一定,书中说很多时候InnoDB让MyISAM望尘莫及。

选择依据:

1、事务:InnoDB支持事务,MyISAM不是事务型存储引擎。

2、InnoDB支持在线热备份。

3、崩溃恢复,InnoDB是事务型存储引擎支持,MyISAM崩溃后修复一个大的表是非常慢的。

4、特有特性,比如聚簇索引,外键约束,行锁等等。

如果对数据安全性要求不高,并且主要读取的并且数据库表不是很大的场景下应用MyISAM。

数据量非常大那么还是用InnoDB吧,当读写非常频繁时候行级锁性能更好。0b1331709591d260c1c78e86d0c51c18.png

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

mysql数据库存储逻辑_MySQL逻辑架构及存储引擎简介 的相关文章

  • 单链表的创建和添加元素(具体代码实现) [数据结构][Java]

    单链表的创建和添加元素 具体代码实现 具体代码如下 实现了单链表的创建和元素的添加 package com ffyc linkedlist public class SingleLinkedList 先初始化一个头结点 头结点不能动 头结点
  • gazebo仿真 机械臂抓取和放置 使用ros_control插件

    仿真截图 rqtgraph ROS Control教程官方 http gazebosim org tutorials tut ros control 下图概述了仿真 硬件 控制器和传输之间的关系 图片分 gazebo仿真 和真实硬件两部分
  • 使用weex,开发美食app之vue页面实现

    这里就带用weex大家做一个简单的app 数据接口来自 阿里云 https market aliyun com products 57126001 cmapi012028 html spm 5176 8216963 738024 10 mt
  • MixFormer: End-to-End Tracking with Iterative Mixed Attention解读

    MixFormer End to End Tracking with Iterative Mixed Attention 代码 文章 https github com MCG NJU MixFormer Abstract 跟踪通常采用特征提
  • root用户无法启动vscode的解决方法

    root用户无法启动vscode 的解决方法 1 vscode with root 2 解决方法 3 总结 1 vscode with root 今天切换到Ubuntu的root用户进行编码调试 发现VSCode一直无法打开 命令提示和网上
  • Failed to compile with 1 error。Syntax Error: Error: Loading PostCSS Plugin failed: Cannot find modul

    Syntax Error Error Loading PostCSS Plugin failed Cannot find module postcss pxtorem 错误 解决啦 方法 npm i postcss pxtorem 5 1
  • 使用 redux 有哪些原则?

    核心描述 单一数据源 整个应用的全局 state 被存储在一棵 object tree 中 并且这个 object tree 只存在于唯一一个 store 中 State 是只读的 唯一改变 state 的方法就是触发 action act
  • Java生成指定时间段的一个随机时间

    package com tsjsr util import java text SimpleDateFormat import java util Date import junit framework TestCase public cl
  • 数组应用: 找出一组数据中比均值大的数据并输出

    数组应用 找出一组数据中比均值大的数据并输出 问题描述 由键盘输入读取整型数据 数据数量不超过100个 当读取到数据 1时 停止读取数据 并计算这些数据的均值 不包含 1 将大于均值的数据输出 问题分析 给定了数据数量不超过100 若将每个
  • java设计模式---- 适配器模式,手写SpringMVC适配器设计模式

    主文章 所有java设计模式的目录 https blog csdn net grd java article details 122252696 源码位置 码云 https gitee com yin zhipeng design mode
  • seaborn官方文档的一些坑(以tips为例)

    初次接触seaborn的一个问题 Seaborn 是一个基于 matplotlib 且数据结构与 pandas 统一的统计图制作库 主要特点是画风优良 图形类别更加多样 但数据结构依赖pandas库 比matplotlib pyplot少了
  • 转:浅谈HTTP中Get、Post、Put与Delete的区别

    1 GET请求会向数据库发索取数据的请求 从而来获取信息 该请求就像数据库的select操作一样 只是用来查询一下数据 不会修改 增加数据 不会影响资源的内容 即该请求不会产生副作用 无论进行多少次操作 结果都是一样的 2 与GET不同的是
  • Conda安装Postgresql数据库

    conda search postgresql 查询数据库可安装版本 conda install postgresql 12 2 安装12 2版本的postgresql 创建一个新的PostgreSQL数据库集簇 initdb创建一个新的P
  • ruoyi数据权限学习

    思路 用户关联了角色 用户可以关联多个角色 给角色设置数据权限分类 数据权限分类有如下5种 全部数据权限 DATA SCOPE ALL 自定数据权限 DATA SCOPE CUSTOM 部门数据权限 DATA SCOPE DEPT 部门及以
  • Keil MDK的CMSIS USART Driver使用

    前言 本文适用于使用过Keil MDK软件且有一定的单片机开发基础的人员 软件版本 Keil MDK v5 24 硬件开发板 STM32F429I Discovery 预备知识 Keil RTX线程使用 Keil MDK v5新增了pack
  • 即时通-openfire设备SSL证书部署指南

    一 什么是OpenfireOpenfire 采用Java开发 开源的实时协作 RTC 服务器基于XMPP Jabber 协议 您可以使用它轻易的构建高效率的即时通信服务器 Openfire安装和使用都非常简单 并利用Web进行管理 单台服务
  • 英文论文如何看?转自知乎

    SoniaYang 因为去年年中刚完成了我的硕士论文 就来谈点个人经验 不知道你指的文献指的是 期刊论文 or 学术原著 如果是 期刊论文 那就得首先看Abstract 摘要 一般Abstract包括了这篇文章最基本最全面的几个要素 就是整
  • SQL 统计表 b 对应表a个数,并赋值给表a的一个字段

    最近遇到这么个问题 表a 歌单表 music list 表b 歌曲详情表 music detail 一个歌单对应多个歌曲详情 但在表的设计时 没有考虑到在 music list 设置一个字段标记对应的 music detail数据条数 在数
  • 悄悄分享 60 个相见恨晚的神器工具

    让 WebP 图片下载为 PNG 格式 从 Github 批量下载表情包 一键滚动截屏整个网页 助你快速成为 B 站老司机 一键分析网站技术栈 翻录网页视频神器等等 这些功能 都能在 Chrome 中使用件简单实现 不信 你往下看就行了 最

随机推荐

  • Spring Boot集成Swagger3.0,Knife4j导出文档

    文章目录 Spring Boot集成Swagger3 0 Knife4j导出文档 效果展示 如何使用 简要说明 添加依赖 添加配置类 测试接口 token配置位置 问题1 多文件上传 方法一 配置全局参数 方法二 开启动态参数 自定义多个文
  • Callable日常使用

    Callable日常使用 前言 之前在项目中有个多线程校验导入数据的额需求 就想到了callable 既有返回值又可以抛出异常 岂不美哉 工作之余总结下callable的使用 方便后期CV 目录 Callable日常使用 一 自定义call
  • 360安全卫士添加信任区

    系列文章目录 文章目录 系列文章目录 前言 一 添加信任区 二 步骤 1 木马查杀 2 信任区 3 添加信任的文件 总结 前言 360安全卫士经常会误报 虽然有想过卸载360 但他的有些小工具还挺实用 哎 鸡肋啊 一 添加信任区 打开360
  • 上一个说软件测试简单的,已经被面试官问emo了···

    现在已经过了 不会但我会学 就能感动面试官的时代 随着供需关系的变化 不论是对于面试官还是面试者 面试的成本越来越高 为了筛选到更优秀的程序员 面试官们可谓是绞尽了脑汁 面试造火箭 工作拧螺丝 的传言也不是空穴来风 那些面试官最喜欢的就是你
  • oracle碎片小结

    author skate time 2010 05 31 我们在使用windows的时候 都知道要定期整理磁盘碎片 因为磁盘碎片会影响性能 给管理上带来额外的负担 那oracle更是如此 当随着数据增加 oracle处理海量数据本身就已经很
  • 2021-11-08

    https learnku com docs the way to go 104 tag structure 3642 https mp weixin qq com s 3sjlDFSthVK3 E54TqqUqw
  • faster-rcnn(pytorch)参数配置修改

    修改模型配置文件 train prototxt文件 input data层的num class数值由21改为类别数目 roi data层的num class数值由21改为类别数目 cls score层的num output数值由21改为类别
  • 通过Python2.7访问Oracle

    环境 Python 2 7 cx Oracle 7 3 0 instantclient basic linux x64 version zip unzip instantclient basic zip unzip d cx Oracle
  • 6.Docker Desktop 安装使用教程

    本文目录 1 前言 2 下载 Docker Desktop 3 安装 Docker Desktop 1 配置 Docker Desktop 环境 2 安装 wsl2 2 下载并安装 3 打开 Docker Desktop 的问题 1 问题一
  • 【高级CSS属性】那些年轰动一时的5个CSS高级属性(附源码)

    文章目录 写在前面 涉及知识点 1 empty选择器 1 1 应用场景及效果 1 2 代码实现 2 gap属性 2 1 应用场景及效果 2 2 代码实现 3 伪类 invalid 应用 3 1 应用场景及效果 3 2 代码实现 4 back
  • Es java分页查询列表数据

    Autowired private RestHighLevelClient client public List
  • Android 计算View的深度

    这次遇到一个需求 需要计算当前View的深度 基本上就是大学时候数据结构里求二叉树的解法 记录一下 理论上也可以用于性能优化和性能监控 private int maxDeep View view view不会有子view所以就返回0 if
  • 4.2 线性方程组有解判断

    文章目录 系数矩阵 增广系数矩阵 方程组的矩阵与向量表示形式 结论 判断方程组有无解的步骤 求线性方程组的一般思路 例题 参考 系数矩阵 增广系数矩阵 方程组的矩阵与向量表示形式 求解方程组就是对增广矩阵做初等行变换将系数矩阵化为行简化阶梯
  • Python——算法

    文章目录 算法 1 世界末日 2 马虎的算式 3 振兴中华 4 斐波那契数列 5 武功秘籍 6 切面条 7 立方变自身 8 圆的面积 9 字母图形 10 Huffuman树 算法 1 世界末日 曾有邪教称1999年12月31日是世界末日 当
  • 游戏开发unity插件DoTween:实现人物向目标方向旋转

    已知世界坐标下目标对象的朝向向量B 当前人物朝向向量A transform forward 如何用DoTween实现人物旋转动画呢 Vector3 forwardWorldVector B float duration 0 5f trans
  • 产品研发流程

    需求管理流程介绍 1 1需求管理流程 产品研发的生命周期 一般需要以下几个环节 1 2常用的调研方法 1 3如何进行访谈 访谈注意事项 1 列调研大纲 根据大纲去调研 2 调研顺序 先流程后细节 1 流程从哪里开始 由谁发起 什么事情触发的
  • 想入手抖音定制生日祝福短视频,没有创意思路怎么办?几个方面带你了解整个流程

    项目 定制派大星生日祝福视频 原理 从抖音引流到微信转为私域流量 成本 一部手机 一个微信小号 需要的资源 配音声优 视频素材 一个抖音号 剪辑工具 剪映 这是一个淘宝商品改造成抖音的玩法项目 一 需求思路 儿童喜欢看的动画片人物 比如 派
  • ubuntu16.04开起wifi热点

    1 首先保证电脑连接有线网络 2 点击电脑屏幕右上方联网图标 选择最后一个选项 编辑连接 3 进入如下页面 选中选中wifi选项 点击添加 4 进入如下页面 选择连接类型为wifi 点击新建 5 进入如下页面 填写连接名称与SSID 这两项
  • java深度克隆工具类——支持对象和对象集合

    正经学徒 佛系记录 不搞事情 第一步 创建工具类 直接使用commons beanutils实现对象拷贝 引入pom
  • mysql数据库存储逻辑_MySQL逻辑架构及存储引擎简介

    MySQL逻辑架构 并发控制 由锁实现 读锁 也叫共享锁 读锁互相不阻塞 A加锁表后A b c d都能读该表但不能写该表 写锁 也叫排他锁 写锁相互阻塞 A加排他锁后 其他线程不能读写该表 锁粒度 表锁 锁一个表 并发粒度小 代表存储引擎M