MySQL 数据库经常使用存储引擎的特色

数据库的存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行建立、查询、更新和删除数据。不一样的存储引擎提供不一样的存储机制、索引技巧、锁定水平等功能,使用不一样的存储引擎,还能够 得到特定的功能。如今许多不一样的数据库管理系统都支持多种不一样的数据引擎。MySql的核心就是插件式存储引擎,而其中最知名的就是 MyISAM 及 InnoDB。mysql

  • 存储引擎的查看sql

  • 查看数据库可配置的存储引擎数据库

    SHOW ENGINES;
  • 查看数据库正在使用的存储引擎vim

    show table status from 库 where name='表1';    #查看表1正在使用的存储引擎
    use 库;    #进入数据库
    show create table 表1;
  • 存储引擎的配置缓存

  • 经过命令修改安全

    use 库;      #进入数据库
    alter table 表1 engine=MyISAM;       #修改存储引擎为MyISAM
    alter table 表2 engine=InnoDB;         #修改存储引擎为InnoDB
  • 经过配置文件修改(切记,仅对以后新建的表有用!)服务器

    vim /etc/my.cnf
    ...
    ...
    [mysqld]
    default--storage-engine=MyISAM      //添加你要设为默认的存储引擎
  • 建立表时直接指定存储引擎
    use 库;    #进入库
    create table 表1(id int)engine=InnoDB;        #修改存储引擎为InnoDB
    create table 表2(id int)engine=MyISAM;       #修改存储引擎为MyISAM
    show create table 表;   #查看

存储引擎的特色介绍及适用场景

  • MyISAM特色介绍及适用场景
    MyISAM基于ISAM存储引擎,并对其进行扩展。它是在Web、数据仓储和其余应用环境下最常使用的存储引擎之一。MyISAM拥有较高的插入、查询速度,但不支持事务。MyISAM主要特性有:并发

    1)能够把数据文件和索引文件放在不一样目录。
    2)表级锁定形式,数据在更新时锁定整个表。
    3)数据库读写过程当中相互阻塞。
    4)能够经过key_buffer_size来设置缓存索引。
    5)数据单独写入或读取 速度快占用资源少。
    6)不支持外键约束,只支持全文索引。
    7)建表时会生成三个文件,文件名均以表的名字开始。
    【 .frm文件存储表定义 | 数据文件的扩展名:.MYD(MYData) | 索引文件的扩展名:.MYI(MYIndex) 】ide

    适用场景: 函数

    1)非事务型应用
    2)只读类应用
    3)空间类应用

  • InnoDB特色介绍及适用场景
    InnoDB是事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定和外键,其为MySQL数据库5.5及之后版本默认存储引擎。InnoDB主要特性有:

    1)InnoDB给MySQL提供了具备提交、回滚和崩溃恢复能力的事物安全(ACID兼容)存储引擎。InnoDB锁定在行级而且也在SELECT语句中提供一个相似Oracle的非锁定读。这些功能增长了多用户部署和性能。在SQL查询中,能够自由地将InnoDB类型的表和其余MySQL的表类型混合起来,甚至在同一个查询中也能够混合。
    2)InnoDB是为处理巨大数据量的最大性能设计。它的CPU效率多是任何其余基于磁盘的关系型数据库引擎锁不能匹敌的。
    3)InnoDB存储引擎彻底与MySQL服务器整合,InnoDB存储引擎为在主内存中缓存数据和索引而维持它本身的缓冲池。InnoDB将它的表和索引在一个逻辑表空间中,表空间能够包含数个文件(或原始磁盘文件)。这与MyISAM表不一样,好比在MyISAM表中每一个表被存放在分离的文件中。InnoDB表能够是任何尺寸,即便在文件尺寸被限制为2GB的操做系统上。
    4)InnoDB支持外键完整性约束,存储表中的数据时,每张表的存储都按主键顺序存放,若是没有显示在表定义时指定主键,InnoDB会为每一行生成一个6字节的ROWID,并以此做为主键。
    5)InnoDB被用在众多须要高性能的大型数据库站点上。
    6)InnoDB不建立目录,使用InnoDB时,MySQL将在MySQL数据目录下建立一个名为ibdata1的10MB大小的自动扩展数据文件,以及两个名为ib_logfile0和ib_logfile1的5MB大小的日志文件。

    适用场景:

    MySQL5.7及之后版本已经支持全文索引以及空间函数。
    适用于大多数OLTP应用(On-Line Transaction Processing联机事务处理过程(OLTP)也称为面向交易的处理过程,其基本特征是前台接收的用户数据能够当即传送到计算中心进行处理,并在很短的时间内给出处理结果,是对用户操做快速响应的方式之一。

  • MyISAM及InnoDB的区别

    MyISAM 和 InnoDB 是许多人在使用MySQL时最经常使用的两个存储引擎,这两个各有优劣,视具体应用而定。基本的差异为:MyISAM 不支持事务处理等高级处理,强调的是性能,其执行速度比 InnoDB 更快,可是不提供事务支持,而 InnoDB 提供事务支持、外部键等高级数据库功能。

总而言之,若是数据表主要用来插入查询记录,则 MyISAM 能提供较高的处理效率;若是要提供提交、回滚、崩溃恢复能力的事务安全(ACID兼容)能力,并要求实现并发控制InnoDB 是一个好的选择。

相关文章
相关标签/搜索