欢迎来到阿里云授权服务中心典名科技有限公司!咨询电话:023-66887777 18623333330

微信
手机版
网站地图

如何选择MySQL的存储引擎

2021-08-11 11:07:39 投稿人 : admin 围观 : 535 次 0 评论

  存储引擎是负责数据的存储和提取的。MySQL支持多种存储引擎,存储引擎之间是可以替换的,所以叫插件式的存储引擎。每个存储引擎都有各自的特点和应用场景。需要特别注意的是,存储引擎是基于表的,而不是数据库。

  02】存储引擎分类

  首先,数据库支持哪些存储引擎,可以通过如下命令查看:

  show engines;

  如何查看已经存在的表使用的是哪种存储引擎?可以使用DDL建表语句,命令如下:

  show create table table_name;-- 例:ENGINE=InnoDB

  在MySQL服务器,表具体是怎么样存储的呢?数据文件的存储路径可以通过以下命令查看:

  show variables like 'datadir';-- /var/lib/mysql/

  默认情况下,每个库对应一个文件夹,而且不管表用的是哪种类型的存储引擎,都会有一个扩展名是frm的表结构定义文件,不同类型的存储引擎存储数据的文件格式不同,具体如下。

  下面介绍下几种常见存储引擎:

  一、InnoDB

  MySQL5.7默认的存储引擎,数据存储在ibd文件中,该文件还会存放相关的索引数据。特点:

  支持事务,支持外键,因此数据的完整性、一致性更高。

  支持行级别的锁和表级别的锁。

  支持读写并发,写不阻塞读(MVCC)。

  特殊的索引存放方式,可以减少 IO,提升查询效率。

  适合经常更新的表或者存在并发读写或者有事务处理的业务系统。

未标题-1.jpg

  二、MyISAM

  MySQL5.5之前默认的存储引擎,数据存储在MYD文件中,相关索引数据存储在MYI文件中。表级锁定限制了读/写的性能,因此在 Web 和数据仓库配置中,它通常用于只读或以读为主的工作。特点:

  支持表级别的锁。

  不支持事务。

  存储了表的行数(count 速度更快)。

  适合只读或以读为主的数据分析项目。

  三、Memory

  特点:

  数据存储在内存里面,所以读写的速度很快,但是数据库重启或者崩溃,数据会全部消失。

  适合做临时表。

  四、CSV

  数据以CSV文件存储。特点:

  不支持索引。

  不允许空行。

  可以直接编辑。

  适合在不同数据库之间导入导出。

  五、Archive

  采用压缩协议进行数据存储,数据存储为ARZ文件格式。

  特点:不支持索引,不支持 update delete。

  适合做数据的备份。

  以上是 MySQL 里面常见的一些存储引擎。

  【03】如何选择存储引擎

  如果对数据一致性要求比较高,需要事务支持,可以使用InnoDB。如果是只读或者大部分只读的表,可以使用MyISAM。


版权声明:本站部分文章内容、图片来源于网友推荐、互联网收集整理而来,仅供大家学习参考,不代表本站立场,如有侵权,请联系站长,我们会第一时间处理!本站原创内容未经允许不得转载,或转载时需注明出处:典名科技资讯门户

相关文章

  • mysql5.7如何修改root密码
    mysql5.7如何修改root密码

    这篇文章主要介绍了mysql5.7如何修改root密码的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql5.7如何修改root密码文章都会有所收获,下面我们一起来看看吧。方法:1、用“set passwo...

    2022-05-23 13:47:02
  • mysql如何修改column
    mysql如何修改column

    这篇文章主要介绍“mysql如何修改column”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql如何修改column”文章能帮助大家解决问题。方法:1、用“alter table 表名 mo...

    2022-05-23 13:47:01
  • mysql的慢查询日志记录哪些内容
    mysql的慢查询日志记录哪些内容

    本篇内容主要讲解“mysql的慢查询日志记录哪些内容”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql的慢查询日志记录哪些内容”吧!在mysql中,慢查询日志记录的是响应时间超过阈值的语句...

    2022-05-23 13:47:01
  • 常见SQL注入类型及原理是什么
    常见SQL注入类型及原理是什么

    这篇“常见SQL注入类型及原理是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“常见SQL注入类型及原理是什么”文章吧。M...

    2022-05-23 13:47:01
  • mysql workbench中如何注释
    mysql workbench中如何注释

    本篇内容介绍了“mysql workbench中如何注释”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mysql workbench中的注释...

    2022-05-23 13:46:58
  • mysql如何修改definer
    mysql如何修改definer

    这篇文章主要介绍“mysql如何修改definer”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql如何修改definer”文章能帮助大家解决问题。修改方法:1、利用“update mysql...

    2022-05-23 13:46:56
  • mysql如何查询当前登录的用户
    mysql如何查询当前登录的用户

    本文小编为大家详细介绍“mysql如何查询当前登录的用户”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql如何查询当前登录的用户”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。方法:1、用USER()函数,...

    2022-05-18 10:01:01
  • mysql如何查询外键约束
    mysql如何查询外键约束

    这篇文章主要介绍了mysql如何查询外键约束的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql如何查询外键约束文章都会有所收获,下面我们一起来看看吧。在mysql中,可以利用show语句查询外键约束,sh...

    2022-05-18 10:01:01
  • mysql查询如何设置降序
    mysql查询如何设置降序

    本篇内容介绍了“mysql查询如何设置降序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在mysql中,可以利用desc关键字对查询结果进行...

    2022-05-18 10:01:00
  • mysql如何修改主键的值
    mysql如何修改主键的值

             这篇文章主要介绍了mysql如何修改主键的值的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql如何修改主键的值文章都会有所收获,下面我们...

    2022-05-18 10:01:00
发表评论