扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
事实上,MyISAM存储引擎对全文索引有很多限制,比如表级锁对性能的影响、数据文件崩溃、崩溃后恢复等,这使得MyISAM全文索引不适合很多应用场景。因此,在大多数情况下,建议使用其他解决方案,如Sphinx、Lucene等第三方插件,或者使用InnoDB存储引擎的全文索引。
创新互联从2013年创立,是专业互联网技术服务公司,拥有项目成都网站建设、做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元宁江做网站,已为上家服务,为宁江各地企业和个人服务,联系电话:18982081108innodb和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(*),则次索引扫描速度更快,而主键主要用于扫描索引并同时返回原始数据。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流