概述

MySQL体系结构图

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的逻辑存储结构图

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

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引擎

优点

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

缺点

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

用途

用作临时表或者缓存

MSQL-->存储引擎的更多相关文章

  1. mysql_存储引擎层-innodb buffer pool

    buffer pool 是innodb存储引擎带的一个缓存池,查询数据时,首先从内存中查询 数据如果内存中存在的话直接返回. innodb buffer pool 和 qcache 的区别:Qcach ...

  2. 《MySQL技术内幕:InnoDB存储引擎》读书笔记

    一.Mysql体系结构和存储引擎 1. 概念:              数据库:物理操作系统文件或其他形式文件类型的集合.(是文件的集合,是依照某种数据模型组织起来并存放于二级存储器中的数据集合.) ...

  3. MySQL数据库和InnoDB存储引擎文件

    参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...

  4. Mysql存储引擎及选择方法

    0x00 Mysql数据库常用存储引擎 Mysql数据库是一款开源的数据库,支持多种存储引擎的选择,比如目前最常用的存储引擎有:MyISAM,InnoDB,Memory等. MyISAM存储引擎 My ...

  5. Mysql存储引擎比较

    Mysql作为一个开源的免费数据库,在平时项目当中会经常使用到,而在项目当中我们的着重点一般在设计使用数据库上而非mysql本身上,所以在提到mysql的存储引擎时,一般都不曾知道,这里经过网上相关文 ...

  6. MongoDB 存储引擎:WiredTiger和In-Memory

    存储引擎(Storage Engine)是MongoDB的核心组件,负责管理数据如何存储在硬盘(Disk)和内存(Memory)上.从MongoDB 3.2 版本开始,MongoDB 支持多数据存储引 ...

  7. TokuDB存储引擎

    TokuDB是Tokutek公司开发的基于ft-index(Fractal Tree Index)键值对的存储引擎. 它使用索引加快查询速度,具有高扩展性,并支持hot scheme modifica ...

  8. MongoDB 存储引擎和数据模型设计

    标签: MongoDB NoSQL MongoDB 存储引擎和数据模型设计 1. 存储引擎 1.1 存储引擎是什么 1.2 MongoDB中的默认存储引擎 2. 数据模型设计 2.1 内嵌和引用 2. ...

  9. 详细介绍Mysql各种存储引擎的特性以及如何选择存储引擎

    最近业务上有要求,要实现类似oracle 的dblink   linux版本 Server version: 5.6.28-0ubuntu0.14.04.1 (Ubuntu) 修改配置文件 /etc/ ...

  10. [MySQL Reference Manual]15. 其他存储引擎

    15. 其他存储引擎 15. 其他存储引擎 15.1 设置存储引擎 15.2 MyISAM存储引擎 15.2.1 MyISAM启动选项 15.2.2 Key的空间要求 15.2.3 MyISAM表存储 ...

随机推荐

  1. MySQL主从复制之半同步(semi-sync replication)

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 半同步简介 MASTER节点在执行完客户端提交的事务后不是立刻返回结果给客户端,而是等待至少一个SLAVE节点接收并写到r ...

  2. Kafka部署安装

    一.环境准备 1.jdk 8+ 2.zookeeper 3.kafka 说明:在kafka较新版本中已经集成了zookeeper,所以不用单独安装zookeeper,只需要在kafka文件目录中启动z ...

  3. MybatisPlus高级特性

    MybatisPlus高级特性 1. 公共字段自动填充 1.1 问题分析 在新增员工时需要设置创建时间.创建人.修改时间.修改人等字段,在编辑员工时需要设置修改时间.修改人等字段.这些字段属于公共字段 ...

  4. 初次认识 Canvas

    画布的概念 Canvas(画布)可以用于动画.游戏画面.数据可视化.图片编辑以及实时视频处理等方面.画布在 HTML5 中是通过canvas标签来表现,通过 JavaScript 提供的画布 API, ...

  5. Excelize 2.5.0 正式发布,这些新增功能值得关注

    Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准.可以使用它来读取.写入由 Microsoft Exc ...

  6. Swift中的Result 类型的简单介绍

    Swift 5引入了一个新的Result类型, 它使用枚举来处理异步函数的结果. 苹果文档对该类型的描述: A value that represents either a success or a ...

  7. vscode 快速注释和撤回快捷键

    好家伙,天天忘,建议先练个十遍上手 1.快捷行注释 Ctrl + / 2.快捷块注释 Alt + Shift + A 3.撤回 Ctrl + Z 4.恢复撤回(撤回你的撤回) Ctrl + Shift ...

  8. KingbaseES 全局临时表

    Postgresql 支持会话级别的临时表,表的存续期只在创建临时表的会话存活期间,会话退出后,临时表自动删除,表结构及数据也无法跨会话共享.KingbaseES 除了支持PG原生的临时表机制外,还支 ...

  9. KingbaseFlySync V1R6 管控平台Linux命令行安装

    关键字: KingbaseFlySync.KingbaseES.Linux.x86_64.mips64el.aarch64.Java 管控平台: Web管控平台(Manager.Console.Com ...

  10. CentOS7_SSH_安装总结

    在使用ssh 连接自己的centos 虚拟机时,发现连接不上,于是有了这个安装过程 (以下是在root用户下执行的,没权限的话就sudo) 1.首先判断是否有这个服务 systemctl list-u ...