Innodb引擎概述

Innodb引擎提供了对数据库ACID事务的支持,并且实现了SQL标准的四种隔离级别。该引擎还提供了行级锁和外键约束,它的设计目标是处理大容量数据库系统,它本身其实就是基于MySQL后台的完整数据库系统,MySQL运行时Innodb会在内存中建立缓冲池,用于缓冲数据和索引。但是该引擎不支持FULLTEXT类型的索引,而且它没有保存表的行数,当SELECT COUNT(*) FROM TABLE时需要扫描全表。当需要使用数据库事务时,该引擎当然是首选。由于锁的粒度更小,写操作不会锁定全表,所以在并发较高时,使用Innodb引擎会提升效率。但是使用行级锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表。

MyISAM引擎概述

MyISAM是MySQL默认的引擎,但是它没有提供对数据库事务的支持,也不支持行级锁和外键,因此当INSERT(插入)或UPDATE(更新)数据时即写操作需要锁定整个表,效率便会低一些。不过和Innodb不同,MyISAM中存储了表的行数,于是SELECT COUNT(*) FROM TABLE时只需要直接读取已经保存好的值而不需要进行全表扫描。如果表的读操作远远多于写操作且不需要数据库事务的支持,那么MyISAM也是很好的选择。

简单介绍区别:

1、MyISAM是非事务安全的,而InnoDB是事务安全的

2、MyISAM锁的粒度是表级的,而InnoDB支持行级锁

3、MyISAM支持全文类型索引,而InnoDB不支持全文索引

4、MyISAM相对简单,效率上要优于InnoDB,小型应用可以考虑使用MyISAM

5、MyISAM表保存成文件形式,跨平台使用更加方便

应用场景:

1、MyISAM管理非事务表,提供高速存储和检索以及全文搜索能力,如果再应用中执行大量select操作,应该选择MyISAM

2、InnoDB用于事务处理,具有ACID事务支持等特性,如果在应用中执行大量insert和update操作,应该选择InnoDB

-

mysql myisam 全文检索,mysql索引区别innodb和MyISAM相关推荐

  1. MySQL学习笔记--常用存储引擎InnoDB与MyISAM总结

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一.MyISAM 特性 1. 并发性与锁级别 2. 表损坏修复 3. MyISAM表支持的索引 4. MyISAM表支持压缩 ...

  2. mysql的存储过程和索引区别_mysql查看索引与存储过程

    mysql查看索引与存储过程创建索引: CREATE INDEX可对表增加普通索引或UNIQUE唯一索引. CREATE INDEX index_name ON table_name (column_ ...

  3. 锁表:MyISAM非聚集索引和InnoDB聚集索引的各种锁表问题

    参考文献 Mysql数据库中的各种锁_张花生的博客-CSDN博客_数据库锁 面试官:MySQL死锁有哪些场景?如何避免? 概述 相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存 ...

  4. mysql会自动建立索引_mysql innodb 索引是自动建立的吗

    ALTER TABLE t1 ADD INDEX(or CREATE INDEX) ALTER TABLE t1 ADD FULLTEXT INDEX ALTER TABLE t1 ADD COLUM ...

  5. mysql索引innodb和myisam的区别

    引用 引用 区别 InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一 ...

  6. mysql innodb myisam 区别_InnoDB与MyISAM的六大区别_MySQL

    bitsCN.com 本文主要整理了Mysql 两大常用的存储引擎MyISAM,InnoDB的六大常见区别,来源于Mysql手册以及互联网的资料 InnoDB与Myisam的六大区别 MyISAMIn ...

  7. 常用Mysql存储引擎--InnoDB和MyISAM简单总结

    常用Mysql存储引擎--InnoDB和MyISAM简单总结 2013-04-19 10:21:52|  分类: CCST|举报|字号 订阅 MySQL服务器采用了模块化风格,各部分之间保持相对独立, ...

  8. mysql 事务的好坏_mysql存储引擎:InnoDB和MyISAM的差别/优劣评价/评测/性能测试

    InnoDB和MyISAM简介 MyISAM:这个是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的 顺序访问方法) 的缩写 ...

  9. MySQL(三):InnoDB和MyISAM

    文章目录 一.InnoDB 和 MyISAM的不同 一.InnoDB 和 MyISAM的不同 InnoDB 支持事务,MyISAM 不支持.对于InnoDB每一条SQL语言都默认封装成事务,自动提交, ...

最新文章

  1. igstk 学习笔记
  2. java工程师面试如何自我介绍
  3. Java内存泄露原因详解
  4. 程序自动分析(洛谷-P1955)
  5. Interlocked..::.Add 方法
  6. CCF202012-2 期末预测之最优阈值
  7. 12.15 Ext JS 选人组件
  8. python import _ssl_Python 3没有名为’_ssl’的模块
  9. IP地址、IP段通俗化介绍
  10. linux 路由跟踪命令_一文掌握linux系统路由跟踪指令traceroute
  11. php 图片上传 文件上传 大小 限制
  12. 记住看小电影前一定要检查一下域名是不是 HTTPS 的,不然……
  13. android View的层级结构
  14. 20210311 plecs 对传递函数进行波特图分析
  15. 操作系统概念之OSAL
  16. linux达梦服务重启,如何重启达梦数据库服务
  17. Facebook攻略--注册流程
  18. C/C++——set的基本操作总结
  19. 爬虫返回乱码以及解决办法以及锟斤拷、ISO-8859-1转码、#、#x转码、unicode转码,gbk转码,ascii转码
  20. 了解python正则表达式

热门文章

  1. QT中toPlainText()和text()的使用
  2. 小白重装系统教程_小白稳定版 | U盘重装系统教程
  3. python爬取数据的原理_Python爬虫原理
  4. spring 框架的作用
  5. 【python】15行代码实现猫脸检测(opencv)
  6. mac下复制、剪切文件,获得文件路径
  7. 日更第11天:Linux常用命令之chmod用法
  8. 钣金缺口lisp_AtuoCAD二次开发---钣金系统开发
  9. linux三剑客之awk命令详解
  10. Chrome 无法打开12306 解决方案