2016 - 2024

感恩一路有你

myisam为什么比innodb查询快 innodb和myisam区别?

浏览量:1956 时间:2021-03-16 20:47:18 作者:admin

innodb和myisam区别?

MyISAM和InnoDB之间的七个区别:1。MySQL默认采用MyISAM。MyISAM不支持事务,而InnoDB支持事务。InnoDB的Autommit默认打开,即每条SQL语句默认封装为一个事务,并自动提交,影响速度。因此,最好在begin和commit之间显示多个SQL语句,以形成要提交的事务。

2. InnoDB支持行锁定,而MyISAM不支持。它只支持锁定整个表。也就是说,MyISAM的同一个表上的读锁和写锁是互斥的。如果队列中同时存在读请求和写请求,则默认情况下写请求的优先级较高。即使读取请求先到达,MyISAM也不适合大量查询和修改并存的情况,因此查询过程会被长时间阻塞。因为MyISAM是一个锁表,所以读操作非常耗时,其他写进程也会饿死。

3. InnoDB支持外键,但MyISAM不支持。

4. InnoDB的主键范围更大,是MyISAM的两倍。

5. InnoDB不支持全文索引,而MyISAM支持。全文索引是指为char、varchar和text中的每个单词(停止词除外)建立倒排索引。MyISAM的全文索引实际上是无用的,因为它不支持中文分词。必须在分词后加空格写入数据表,少于4个汉字的词作为停止词将被忽略。

6. MyISAM支持GIS数据,但InnoDB不支持。也就是说,MyISAM支持以下空间数据对象:点、线、多边形、曲面等。使用MyISAM而不计算(*)where要比使用InnoDB快得多。因为MyISAM有一个内置的计数器,当count(*)时,它直接从计数器中读取,而InnoDB必须扫描整个表。因此,在InnoDB上执行count(*)时,通常伴随where,where应该包含主键以外的索引列。为什么特别强调“外主键”?在InnoDB中,主索引和原始数据一起存储,而次索引分开存储,然后有一个指向主键的指针。因此,如果只使用count(*),则次索引扫描速度更快,而主键主要用于扫描索引并同时返回原始数据。

myisam和innodb的区别?

没有这么简单的比较。如果是这样,请使用MyISAM来读取更多的表,使用InnoDB来写入更多的表。

有很多因素需要考虑,我列出了一些:

1。如果你能将数据缓存在内存中,速度就不会有太大的差别。此时,获取数据的速度取决于物理硬件限制;

2。访问模式与访问速度有关。如果并发度高,表锁的性能一般比行锁差,因为要处理并发冲突;

3。大多数小公司,或在早期,公司使用简单的MyISAM。其性能要求不高,表格数据相对较少。此时,MyISAM“似乎”很大。如果数据量大,公司就会发展,业务逻辑关系就会复杂。此时,对数据库的测试就是缓存和优化器的设计。如此简单的MyISAM引擎怎么能比InnoDB更快呢。MyISAM使用操作系统来缓存数据。操作系统不知道如何优化数据库访问,而InnoDB使用自己的缓存功能来加速访问。您应该知道,优化离应用程序/数据端越近,它就越有效。

myisam为什么比innodb查询快 myisam和innodb是什么 myisam和innodb的区别

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。