黑马程序员技术交流社区

标题: 用Mysql时不知用何种存储引擎,那就看这个帖 [打印本页]

作者: huawei    时间: 2016-10-14 12:01
标题: 用Mysql时不知用何种存储引擎,那就看这个帖
本帖最后由 huawei 于 2017-3-5 10:56 编辑

用Mysql时不知用何种存储引擎,那就看这个帖


   Mysql是著名的关系型数据库。其下面的关系数据库表是用于存储和组织信息的数据结构,可以将表理解为由行和列组成的表格,类似于Excel的电子表格的形式。有的表简单,有的表复杂,有的表根本不用来存储任何长期的数据,有的表读取时非常快,但是插入数据时去很差;而我们在实际开发过程中,就可能需要各种各样的表,不同的表,就意味着存储不同类型的数据,数据的处理上也会存在着差异,那么。对于MySQL来说,它提供了很多种类型的存储引擎,我们可以根据对数据处理的需求,选择不同的存储引擎,从而最大限度的利用MySQL强大的功能。

       MySQL有很多的数据库引擎,单一般也就用MyISAM和InnoDB。现在就来分析下MySQL最常用的两种存储引擎 innodb和Myisam的差别,以便大家能够在使用的时候清楚知道应使用哪种!


1. 事务处理(一个事务是一个连续的一组数据库操作):

      innodb 支持事务功能,myisam 不支持。
        Myisam 的执行速度更快,性能更好。

2. 增删改查:

      如果执行大量的SELECT,MyISAM是更好的选择,MyISAM会比Innodb 的查询速度快。
        InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表。

3. 锁机制不同:

       InnoDB 为行级锁,myisam 为表级锁。
       注意:当数据库无法确定,所找的行时,也会变为锁定整个表。

4. 查询表的行数不同:

        MyISAM:select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含   where条件时,两种表的操作是一样的
        InnoDB : InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行

5. 物理结构不同

        MyISAM :每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。
         文件存储表定义.frm
         数据文件的扩展名为.MYD (MYData)。
         索引文件的扩展名是.MYI (MYIndex)

        InnoDB:基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的大小只受限于操作系统文件的大小,一般为 2GB。
6、使用场景不同

       MyISAM是默认使用的。但由于MyISAM不支持外键的约束,而且MyISAM会在添加或者更新数据的时候将整个表锁住,所以使用MyISAM更多的是你在建立一个非常简单的数据库或者只是实验性的!
       如果要保证数据完整,还想避免以后扩展性能上不会有很大的问题,那就用InnoDB!








作者: Quasimodo2    时间: 2016-10-14 12:24
不错,不错





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2