MySQL数据库存储引擎

  • MySQL数据库存储引擎

    • 存储引擎概念

      • 存储引擎也称为表类型

      • 通过不同的技术比如说,存储机制,索引技巧,锁定水平等等,来提供不同的功能。

    • 查看MySQL支持的存储引擎

      • show engines\G;

    • 常用引擎比较

      • 对事务有需求

        • innodb
      • 对写入,无索引查询有需求

        • myisam
      • memory不如使用非关系数据库

    • 引擎选择

      • 存储引擎是针对表来说的,选择什么样的存储引擎取决于表内数据的类型,一旦确定了存储引擎并开始使用后,在修改存储引擎会造成较大的麻烦。因此一定要结合需求来慎重决定存储引擎。
    • myisam存储引擎

      • 文件

        • .frm 元数据(表结构)

        • .MYD 表数据

        • .MYI 表索引

      • 表级锁定

    • innodb存储引擎

      • 文件

        • .frm 表结构

        • .ibd 表数据与表索引

      • 行级锁定,外键约束

        • 当用模糊查询时还是会锁定表 where没有使用主键时。
      • 优势

        • 能够处理多并发的更新请求

        • 事务型存储引擎

        • 自动灾难恢复

        • 支持外键

        • 支持自增长设置

          • auto_increment

          • 一般设置为自增长的列就适合作为主键索引,或者唯一索引。

    • 修改存储引擎的方法

      • 方法一

        • alter table 表名 engine=引擎名;
      • 方法二

        • 修改配置文件/etc/my.cnf

          • default-storage-engine=引擎名称
      • 方法三

        • 创建时指定

          • create table 表名(字段,。。。)values (值,。。。)engine=引擎名称;
      • 方法四

        • 临时修改,生效整个登录过程

          • set default_storage_engine=引擎名称
    • 实验比较

      • 从多个因素比较myisam与innodb的差异

      • 实验准备

        • 创建库

          • create database auth

          • 进入到该库:use auth

        • 创建表

          • create table tm(id int(20) primary key auto_increment,name char(30)) engine=myisam;

          • create table ti(id int(20) primary key auto_increment,name char(30)) engine=innodb;

          • 将id列设为主键以及自动增长方便"存储过程"的编写。

        • 创建存储过程

          • 修改数据库结束符

            • delimiter $
          • 创建存储过程

            • create procedure insertm() begin set @i=1; while @i<=10000000 do insert into tm(name) values(concat("wy",@i)); set @i=@i+1; end while; end $

            • 在创建第二个存储过程只需要将上个存储过程中的m修改为i即可表示时innodb的引擎。

          • 最后修改回结束符

            • delimiter $
        • 呼叫存储过程

          • call insertm

          • call inserti

          • 从这个过程中可以明显的比较出两者的差异,myisam时快的多。

        • 使用无索引搜索

          • select * from tm where name>"wy100" and name <"wy10000000"

          • 进行相关查询后发现myisam在无索引搜索方面有优势。

        • 使用索引搜索

          • select * from tm where id>10 and id<999999;

          • 在这方面inonodb有较大优势

将上述全部复制,粘贴到xmind即可看到条理性笔记。

相关推荐
DaqunChen2 分钟前
SQL如何检测分组内是否存在满足条件的数据_EXISTS结合分组
jvm·数据库·python
脑子加油站3 分钟前
OpenEuler24.03 分布式配置redis 集群
数据库·redis·分布式·php·nginx代理
2301_803538955 分钟前
Bootstrap 5栅格系统的五列等分布局方案
jvm·数据库·python
粉嘟小飞妹儿7 分钟前
如何用 error 事件全局捕获页面图片或脚本加载失败状态
jvm·数据库·python
2301_815279529 分钟前
如何在导航栏中实现左右两端对齐的菜单项布局
jvm·数据库·python
专注VB编程开发20年12 分钟前
VBA/VB6 ADO数据库查询jet+只读更快
开发语言·数据库·ado·vb
Wyz2012102413 分钟前
宝塔面板安装后显示无法连接数据库_检查MySQL服务状态
jvm·数据库·python
2301_7775993714 分钟前
Redis如何优化大量对象存储_利用Hash结构减少内存碎片占用
jvm·数据库·python
同元软控14 分钟前
同元软控“电力能源系统数智运维解决方案”入选2025年江苏省信息技术应用创新典型解决方案
运维·数据库·能源
2301_7775993715 分钟前
Python怎么解压tar.gz_tarfile模块提取打包文件操作
jvm·数据库·python