MSQL–>存储引擎

概述

MySQL体系结构图

MSQL-->存储引擎

Innodb引擎是在mysql的5.5版本之后的默认存储引擎。

Index是在引擎层次的,不同的存储引擎index的用法不同。

存储引擎就是存储数据,建立索引,更新查询数据等技术的实现方式。

存储引擎是基于表的而不是基于数据库的,故存储引擎又叫 表的类型

语法

查询当前表的存储引擎类型

show create table 表名;

指定存储引擎

create table 表名(
...

)engine=存储引擎;

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

show engines;

存储引擎的特点

Innodb存储引擎的特点

  1. DML语句支持ACID模型
  2. 支持事务
  3. 行级索引,提高了并发访问的性能
  4. 支持外键,确保了数据的完整性和正确性

文件组成

每一个innodb表都对应了一个 xxx.idb 文件来存储该表的结构,数据

Innodb的逻辑存储结构图

MSQL-->存储引擎

表空间–>段–>区–>页–>行

Myism存储引擎的特点

特点

  1. 不支持事务
  2. 不支持外键
  3. 不支持行锁
  4. 支持表锁
  5. 访问速度很快

文件组成

一共myism表有三个文件

  • xxx.sdi 存储表结构信息
  • xxx.myd 存储表的数据信息
  • xxx.myi 存储表的索引信息

Memory存储引擎的特点

特点

  1. 存储所在内存当作,一般用来当临时表使用
  2. 支持哈希索引

文件组成

xxx.sdi 存储表的结构

三张表的区别

特点 Innodb MyISAM Memory 存储限制 64TB 有 有 事务安全 支持 — — 锁机制 行锁 表锁 表锁 B+tree索引 支持 支持 支持 Hash索引 — — 支持 全文索引 5.6版本后支持 支持 — 空间使用 高 底 N/A 内存使用 高 低 中等 批量插入的速度 低 高 高 支持外键 支持 — —

存储引擎的选择

Innodb引擎

  1. 对事物的完整性有较高要求
  2. 在并发条件下要求事务一致性
  3. 数据操作除了插入和查询外包含了大量的更新删除操作

Myism引擎

  1. 以读取和插入为主,只进行少量的更新和删除操作
  2. 对数据的完整性和事务的并发性要求不高

Memory引擎

优点

将数据存储到内存中,访问速度极快

缺点

对表的大小有限制,太大的表无法存入,数据的安全性无法保障

用途

用作临时表或者缓存

Original: https://www.cnblogs.com/wdadwa/p/MYSQL_Learning_06.html
Author: wdadwa
Title: MSQL–>存储引擎

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/611832/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • python中组合数据的操作

    2022-09-26 组合数据类型: 拷贝: deep(深拷贝) shallow(浅拷贝) 区别:例如,文件中有一个指针指向另一块存储空间,如果是深拷贝则将指向的那一块文件内容也全…

    数据库 2023年6月14日
    0100
  • Mysql 实现数据库读写分离

    一、Amoeba 是什么 Amoeba(变形虫)项目,专注 分布式数据库 proxy 开发。座落与Client、DB Server(s)之间。对客户端透明。具有负载均衡、高可用性、…

    数据库 2023年6月14日
    095
  • python实现Mysql数据库批量新增数据

    一、批量插入数据的场景 二、插入数据的工具选择 三、选择Python进行批量插入 Python实现批量插入Mysql数据库数据 一、批量插入数据的场景 在进行数据压力时需要进行大数…

    数据库 2023年6月6日
    0113
  • 线上问题检测

    ​ jdk 自带工具 1、通过top找到CPU占…

    数据库 2023年6月6日
    0108
  • 3_MyBatis

    一. 引言 1.1 什么是框架? 软件的半成品, 解决了软件开发过程中的普适性问题, 从而简化了开发步骤, 提升了开发效率 1.2 什么是ORM框架? ORM(Object Rel…

    数据库 2023年6月11日
    087
  • Python第五十一天 python2升级为python3

    Python第五十一天 python2升级为python3 公司使用的生产环境系统是centos7,所以这里以centos7系统为基础,讲解将python2升级为python3的方…

    数据库 2023年6月9日
    099
  • 线程池执行流程图

    public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeU…

    数据库 2023年6月16日
    0136
  • Docker安装和配置

    sudo yum install -y docker-ce docker-ce-cli containerd.io 配置加速(可以理解为类似于Maven的阿里仓库,用于加速镜像的下…

    数据库 2023年6月6日
    091
  • Java中如何遍历字符串呢?

    字符串是程序开发中我们见的最多的一种数据类型 对字符串的操作,也是我们日常涉及的最多的一种操作方式,那么如何遍历字符串为字符并输出呢? 下面笔者讲述三种操作方式,如下所示 1.直接…

    数据库 2023年6月11日
    067
  • 一文读懂Spring框架中Bean的生命周期

    我们先来聊聊bean的生命周期: bean的生命周期图: AbstractAutowireCapableBeanFactory的docreateBean()方法(简单描述): 1….

    数据库 2023年6月6日
    0122
  • SQL函数-聚合函数

    聚合函数 聚合函数是对一组数据进行汇总输出的函数。 输入:一组数据集合输出:单个值 举例:返回一组数据的最大值、平均数、最小、方差等操作。 常见函数举例: 1,AVG函数:返回一组…

    数据库 2023年5月24日
    0131
  • 详解在Linux中安装配置MongoDB

    最近在整理自己私人服务器上的各种阿猫阿狗,正好就顺手详细记录一下清理之后重装的步骤,今天先写点数据库的内容,关于在 Linux中安装配置 MongoDB 说实话为什么会装 Mong…

    数据库 2023年6月11日
    0175
  • 第16章 变量、流程控制与游标

    第16章 变量、流程控制与游标 1. 变量 在MySQL数据库的存储过程和函数中,可以使用变量来存储查询或计算的中间结果数据,或者输出最终的结果数据。 在 MySQL 数据库中,变…

    数据库 2023年6月6日
    0103
  • 7 Java有没有goto

    goto是Java中的保留字,在目前版本的Java中没有使用。 Original: https://www.cnblogs.com/xilichenbokeyuan/p/14149…

    数据库 2023年6月6日
    078
  • windows运行xcopy计划任务 结果是0x4解决方案

    近几天发现一直好好的数据备份计划任务一直返回0x4失败,直接执行bat又是正常的。 bat命令中使用的是xcopy,到处找方案没解决。 今天意外在使用另一个命令时,发现提示:网络连…

    数据库 2023年6月14日
    090
  • day03-拉取在线用户功能

    多用户即时通讯系统03 4.编码实现02 4.2功能实现-拉取在线用户 4.2.1思路分析 客户端想要知道在线用户列表,就要向服务器发送请求(Message),因为只有服务器端保持…

    数据库 2023年6月11日
    0178
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球