mysql里目前只支持4种索引分别是:b-tree,full-text,hash以及r-tree索引
b-tree索引应该是mysql里最广泛的索引的了,除了archive,基本所有的存储引擎都支持它.
1.b-tree在myisam里的形式和innodb稍有不同
在innodb里面有两种形态:其一是primary key形态其leafnode里存放的是数据.而且不仅存放了索引键的数据,还存放了其他字段的数据.其二是secondary index,其leafnode和普通的b-tree差不多,只是还存放了指向主键的信息.
而在myisam里,主键和其他的并没有太大区别.不过和innodb不太一样的地方是,在myisam里,leaf node里存放的不是主键的信息,存的是指向数据文件里的对应数据行的信息.
2.hash索引,目前我所知道的就只有memory和ndb cluster支持这种索引.
hash索引由于其结构,所以在每次查询的时候直接一次到位不行b-tree那样,一点点的前进,所以hash索引的效率高于b-tree.但hash也有缺点,主要如下:
(1)由于存放的是hash值,所以仅支持<=>以及in操作.
(2)hash索引无法通过操作索引来排序,这是因为存放的时候经过hash计算,但是计算的hash值和存放的不一定相等,所以无法排序.
(3)在组合所以里,无法对部分使用索引.
(4)不能避免全表扫描,只是由于在memory表里支持非唯一值hash索引,就是不同的索引键,可能存在相同的hash值.
(5)当存在大量相同hash值得时候,hash索引的效率会变低.
3.full-text索引
full-text在mysql里仅有myisam支持它,而且支持full-text的字段只有char,varchar,以及text数据类型,full-text主要是用来代替like "%***%"效率低下的问题的.
4.r-tree索引
r-tree在mysql很少使用,仅支持geometry数据类型,支持该类型的存储引擎只有myisam,bdb,innodb,ndb,archive几种.相对于b-tree,r-tree的优势在于范围查找.
mysql里sql语句值得注意的地方
1.myisam里所以键的长度仅支持1000字节,innodb是767.
2.blob和text字段仅支持前缀索引.
3.使用!=以及<>不等于的时候mysql不使用索引.
4.当在字段使用函数的时候,mysql无法使用索引,在join的时候条件字段类型不一致的时候,mysql无法使用索引,在组合索引里使用非第一个索引时也不使用索引.
5.在使用like的时候,以%开头,即"%***"的时候无法使用索引,在使用or的时候,要求or前后字段都有索引.
有时候mysql query optimizer会认为使用索引并不是最优计划,所以不使用索引,可以在sql语句里可以用use,force index,当然有时候使用也不会比不用快,所以需要忽略掉index方法是ignore index.
关闭查询缓存sql_no_cache
select sql_no_cache * from table_name;
这样可以让一些很少使用的语句不放在缓存里,查找的时候不会去缓存里找.对应的是强制缓存sql_cache
select sql_cache * from table_name;
另外在my.cnf中如果设置query_cache_type=2的话,那么只有在使用sql_cache后才会使用缓存;
还有mysql里的优先操作hight_priority让mysql优先操作这个语句
select high_priority * fromtable_name;
与其对应的是low_priority;
mysql里还有延时插入insert delayed
insert delayed into table_name....;#当提交之后,mysql返回ok,但不立即插入,二十当mysql有空再插入.假如等待时服务器崩溃,那么所有数据丢失!并且插入不会返回自增id.
再转几个技巧:
强制连接顺序 STRAIGHT_JOIN
SELECT TABLE1.FIELD1, TABLE2.FIELD2 FROM TABLE1 STRAIGHT_JOIN TABLE2 WHERE …
由上面的SQL语句可知,通过STRAIGHT_JOIN强迫MySQL按TABLE1、TABLE2的顺序连接表。如果你认为按自己的顺序比MySQL推荐的顺序进行连接的效率高的话,就可以通过STRAIGHT_JOIN来确定连接顺序。
强制使用临时表 SQL_BUFFER_RESULT
SELECT SQL_BUFFER_RESULT * FROM TABLE1 WHERE …
当我们查询的结果集中的数据比较多时,可以通过SQL_BUFFER_RESULT.选项强制将结果集放到临时表中,这样就可以很快地释放MySQL的表锁(这样其它的SQL语句就可以对这些记录进行查询了),并且可以长时间地为客户端提供大记录集。
分组使用临时表 SQL_BIG_RESULT和SQL_SMALL_RESULT
SELECT SQL_BUFFER_RESULT FIELD1, COUNT(*) FROM TABLE1 GROUP BY FIELD1;
一般用于分组或DISTINCT关键字,这个选项通知MySQL,如果有必要,就将查询结果放到临时表中,甚至在临时表中进行排序。SQL_SMALL_RESULT比起SQL_BIG_RESULT差不多,很少使用。
分享到:
相关推荐
数据库索引是提升查询效率的关键工具,MySQL 中提供了多种类型的索引,包括 FULLTEXT、HASH、BTREE 和 RTREE。本文主要关注前三者,详细解析它们的原理、存储结构和优缺点。 首先,BTree 索引是最常见的索引类型,...
MySQL中的Btree与Hash索引是两种常见的索引类型,每种都有其特定的适用场景和优缺点。这里我们将深入探讨这两种索引的特征以及它们在不同查询操作下的表现。 首先,Btree(B-Tree)索引是MySQL中最常用的索引结构,...
### MySQL索引最佳实践 #### 理解索引的重要性 在数据库管理中,索引是一种数据结构,用于提高查询速度。它对于开发者和数据库管理员(DBA)来说至关重要。索引选择不当可能会导致生产环境中的诸多问题。尽管索引...
MySQL中有几种索引类型,可以简单说说吗? FULLTEXT :即为全文索引,目前只有MyISAM引擎支持。其可以在CREATE TABLE ,ALTER TABLE ,CREATE INDEX 使用,不过目前只有 CHAR、VARCHAR ,TEXT 列上可以创建全文索引...
MySQL中的索引是一种重要的数据结构,...总之,了解并合理利用MySQL的索引可以显著提升数据库性能,特别是通过选择合适的索引类型和创建覆盖索引,能有效优化查询速度,同时注意适时清理缓存以获得准确的性能测试结果。
CREATE INDEX Syntax CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [index_type] ON ... HASH | RTREE} 代码如下: — 创建无索引的表格 create table testNoPK ( id int not null, name varchar(10) ); — 创建
- `index_type`:可选,索引类型,如BTREE(B树,最常用的索引类型)、HASH(哈希索引,适用于等值查询)或RTREE(R树,用于处理多维空间数据)。 以下是一些代码示例: 1. 创建无索引的表格: ```sql CREATE ...
索引是提高查询速度的关键,MySQL支持BTree、Hash、RTree等多种类型的索引。了解如何创建和使用索引,以及如何避免全表扫描,能显著提升查询效率。此外,通过分析查询语句的执行计划,可以优化查询策略,减少不必要...
4. **索引**:了解索引的作用,如何创建(UNIQUE, PRIMARY KEY, FOREIGN KEY, INDEX)索引,以及不同类型的索引(BTree, Hash, RTree)的优缺点和应用场景。 5. **查询优化**:学会使用EXPLAIN分析查询执行计划,...
3. **索引与查询优化**:MySQL 5.1支持多种类型的索引,包括BTree、Hash和RTree,用于加快数据检索速度。手册讲解了如何创建和管理索引,以及使用EXPLAIN来分析查询性能。 4. **存储引擎**:MySQL 5.1引入了InnoDB...
- `index_type`:用于指定索引类型,MySQL支持三种索引类型:BTREE、HASH和RTREE。BTREE适合范围查询,HASH适合等值查询,RTREE适用于空间数据的索引。 这些知识适用于MySQL数据库管理系统,通常也适用于其衍生分支...
MySQL支持不同类型的索引,包括B树(BTREE,适用于大多数情况)、全文索引(FULLTEXT,用于全文搜索)、哈希索引(HASH,适用于等值查询,不支持范围查询)和空间索引(RTREE,用于地理空间数据)。 6. **选择合适...