`

mysql索引hash索引和b-tree索引的区别

 
阅读更多

mysql下增加索引的方式:

修改表结构:

ALTER mytable ADD INDEX [indexName] ON (username(length))

创建表结构

CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, INDEX [indexName] (username(length)) );

删除索引的语法:

DROP INDEX [indexName] ON mytable;

 

下面是mysql具有的索引类型:

1、唯一索引

它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。它有以下几种创建方式:

◆创建索引

CREATE UNIQUE INDEX indexName ON mytable(username(length))

◆修改表结构

ALTER mytable ADD UNIQUE [indexName] ON (username(length))

◆创建表的时候直接指定

CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, UNIQUE [indexName] (username(length)) );

 

 2、主键索引

它是一种特殊的唯一索引,不允许有空值。一般是在建表的时候同时创建主键索引:

CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, PRIMARY KEY(ID) ); 当然也可以用 ALTER 命令。记住:一个表只能有一个主键。

 

 

3、组合索引

为了形象地对比单列索引和组合索引,为表添加多个字段:

CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, city VARCHAR(50) NOT NULL, age INT NOT NULL ); 为了进一步榨取MySQL的效率,就要考虑建立组合索引。就是将 name, city, age建到一个索引里:

ALTER TABLE mytable ADD INDEX name_city_age (name(10),city,age); 建表时,usernname长度为 16,这里用 10。这是因为一般情况下名字的长度不会超过10,这样会加速索引查询速度,还会减少索引文件的大小,提高INSERT的更新速度。

如果分别在 usernname,city,age上建立单列索引,让该表有3个单列索引,查询时和上述的组合索引效率也会大不一样,远远低于我们的组合索引。虽然此时有了三个索引,但MySQL只能用到其中的那个它认为似乎是最有效率的单列索引。

建立这样的组合索引,其实是相当于分别建立了下面三组组合索引:

usernname,city,age usernname,city usernname 为什么没有 city,age这样的组合索引呢?这是因为MySQL组合索引“最左前缀”的结果。简单的理解就是只从最左面的开始组合。并不是只要包含这三列的查询都会用到该组合索引,下面的几个SQL就会用到这个组合索引:

SELECT * FROM mytable WHREE username="admin" AND city="郑州" SELECT * FROM mytable WHREE username="admin" 而下面几个则不会用到:

SELECT * FROM mytable WHREE age=20 AND city="郑州" SELECT * FROM mytable WHREE city="郑州"

 

 

建立索引的时机;

到这里我们已经学会了建立索引,那么我们需要在什么情况下建立索引呢?一般来说,在WHERE和JOIN中出现的列需要建立索引,但也不完全如此,因为MySQL只对<,<=,=,>,>=,BETWEEN,IN,以及某些时候的LIKE才会使用索引。例如:

SELECT t.Name FROM mytable t LEFT JOIN mytable m ON t.Name=m.username WHERE m.age=20 AND m.city='郑州' 此时就需要对city和age建立索引,由于mytable表的userame也出现在了JOIN子句中,也有对它建立索引的必要。

刚才提到只有某些时候的LIKE才需建立索引。因为在以通配符%和_开头作查询时,MySQL不会使用索引。例如下句会使用索引:

SELECT * FROM mytable WHERE username like'admin%' 而下句就不会使用:

SELECT * FROM mytable WHEREt Name like'%admin' 因此,在使用LIKE时应注意以上的区别。

 

使用索引时的注意事项:

1、默认可以为null的列,索引不起作用。

2、使用短索引,不能列的长度有多长,索引就建立多长

3、mysql查询默认只使用一个索引,如果加上排序的话,最好给他们加上复合索引,要不然排序非常影响效率

4、不要在列上做运算,这样会导致索引失效

5、不适用 not in 和<>

分享到:
评论

相关推荐

    MySQL Hash索引和B-Tree索引的区别

    MySQL中的索引是提高查询效率的关键工具,其中两种常见的索引类型是Hash索引和B-Tree索引。这两种索引各有特点,适用于不同的查询场景。 首先,Hash索引以其高效的查找性能脱颖而出。Hash索引的工作原理是通过索引...

    MySQL索引最佳实践

    - 即使多列索引包含多个字段,但它仍然是一个单一的B-Tree索引,并不是每个字段都有单独的B-Tree索引。 #### 七、索引的成本与优化 - 索引本身是有成本的,它不仅会占用存储空间,而且在插入、删除和更新数据时也...

    MySQL索引 使用笔记

    - B-Tree索引适用于范围查询和排序,是最常见的索引类型。 - Hash索引适用于等值查询,速度非常快,但不支持范围查询或排序。 - Full-text索引专用于全文搜索,适合于大量文本数据的搜索。 2. 创建索引: - ...

    MySQL索引优化课件

    B-Tree索引是最常见的索引类型,适合处理范围查询和排序操作。对于多列索引,理解索引合并(index merge)和覆盖索引(covering index)的概念非常重要,这些都可以帮助优化查询性能。例如,覆盖索引允许查询只从...

    MySQL数据库学习笔记(六)----MySQL多表查询之外键、表连接、子查询、索引

    B-Tree索引是最常见的,适用于大多数情况;Hash索引适用于等值查询;R-Tree适用于空间数据;Full-text索引则用于全文搜索。创建和使用正确的索引能显著提升查询性能,但过多的索引可能会增加写操作的开销,因此需...

    mysql索引导出删除

    B-Tree索引是最常见的一种,适用于范围查询和排序;Hash索引则适合等值查找,但不支持范围查询;R-Tree用于空间数据索引;Full-text索引则用于全文搜索。 要导出MySQL数据库中的所有索引信息,我们可以编写一个SQL...

    尚硅谷mysql高级:索引、优化

    B-Tree索引适用于范围查询,而Hash索引适用于等值查询,Full-text索引则专门用于文本搜索。 2. 主键索引:每个表都应有一个主键,其值唯一且不可为NULL。主键索引自动创建并维护,提供快速的数据查找。 3. 唯一...

    0113-(每特教育&每特学院&蚂蚁课堂)-4期-数据库技术-高性能MySQL索引实现原理之实战操作索引.zip

    B-Tree索引通过平衡多路搜索树结构,确保查找、插入和删除操作的时间复杂度保持在对数级别。 课程可能涉及的索引原理包括: 1. **唯一性索引**:确保表中某一列的值是唯一的,如主键索引。 2. **非唯一性索引**:...

    数据库索引那些事(数据库索引原理)

    数据库索引的实现方式有多种,常见的有 B-Tree 索引、Hash 索引、fulltext 全文索引、bitmap 位图索引等。其中,B-Tree 索引是最常用的索引类型,例如 MsSql 使用的是 B+Tree 索引,Oracle 使用的是 B-Tree 索引。...

    MySQL高级篇-索引(Index)的数据结构

    B-Tree索引适用于等值查询和范围查询,且在插入、删除和更新操作时能保持较好的性能。 四、聚集索引与非聚集索引 1. 聚集索引(Clustered Index):索引结构与数据行存储在一起,索引的顺序决定了数据行的物理存储...

    一文搞懂MySQL索引所有知识点

    2. Hash索引:主要用于等值查询,其查找速度非常快,但不支持范围查询和排序。适用于内存优化表或需要快速查找的场景。 3. R-Tree索引:主要用于地理空间数据,支持多维数据索引,适用于地理信息系统的应用。 4. ...

    MySQL索引最佳实践1

    MySQL索引最佳实践是数据库管理中的重要环节,它关乎到数据查询速度、系统性能和资源利用率。本篇文章将深入探讨MySQL索引的原理、类型、最佳实践以及它们对数据库操作的影响。 首先,索引的主要目的是加快数据访问...

    Mysql索引优化实战.zip

    B-Tree索引是默认的索引类型,适用于范围查询和排序;Hash索引则适用于等值查询,但不支持范围查询和排序;R-Tree用于多维数据,如地理坐标;Bitmap索引则在数据仓库中常见,适合于大量数据的低选择性查询。 接下来...

    mysql索引笔记1

    2. **Hash索引**:适用于等值查询,但不支持范围查询和排序。 3. **Full-Text索引**:用于全文搜索。 4. **R-Tree索引**:主要用于空间数据索引。 创建和管理索引的基本语法包括: - **创建索引**:CREATE INDEX 或...

    mysql 索引1

    Hash索引则适用于等值查询,但不支持范围查询和排序。Full-text索引专为全文搜索设计,而R-Tree适用于处理多维数据,如地理坐标。 1.4 创建索引语法: 创建索引的基本语法是`CREATE INDEX index_name ON table_name...

    5分钟掌握Mysql索引使用和失效.zip

    B-Tree索引是最常见的一种,适用于范围查询、排序和唯一性检查。 要提高数据检索效率,应尽可能为经常用于搜索、排序和连接操作的列创建索引。例如,主键和外键列通常自动带有索引。此外,对于频繁出现在WHERE子句...

Global site tag (gtag.js) - Google Analytics