[MySQL][索引操作]详细讲解


1.创建主键索引

1.操作

  • 第一种方式
    -- 在创建表的时候,直接在字段名后指定 primary key
    create table user1(id int primary key, name varchar(30));
    
  • 第二种方式
    -- 在创建表的最后,指定某列或某几列为主键索引
    create table user2(id int, name varchar(30), primary key(id));
    
  • 第三种方式
    create table user3(id int, name varchar(30));
    
    -- 创建表以后再添加主键
    alter table user3 add primary key(id);
    

2.主键索引特点

  • 一个表中,最多有一个主键索引,当然可以是复合主键
  • 主键索引的效率高(主键不可重复)
  • 创建主键索引的列,它的值不能为null,且不能重复
  • 主键索引的列基本上是int

2.创建唯一索引

1.操作

  • 第一种方式
    -- 在表定义时,在某列后直接指定unique唯一属性。
    create table user4(id int primary key, name varchar(30) unique);
    
  • 第二种方式
    -- 创建表时,在表的后面指定某列或某几列为unique
    create table user5(id int primary key, name varchar(30), unique(name))
    
  • 第三种方式
    create table user6(id int primary key, name varchar(30));
    alter table user6 add unique(name);
    

2.唯一索引的特点

  • 一个表中,可以有多个唯一索引
  • 查询效率高
  • 如果在某一列建立唯一索引,必须保证这列不能有重复数据
  • 如果一个唯一索引上指定not null,等价于主键索引

3.创建普通索引

1.操作

  • 第一种方式
    create table user8(id int primary key,
    	name varchar(20),
    	email varchar(30),
    	index(name) --在表的定义最后,指定某列为索引
    );
    
  • 第二种方式
    create table user9(id int primary key, name varchar(20), email varchar(30));
    alter table user9 add index(name); --创建完表以后指定某列为普通索引
    
  • 第三种方式
    create table user10(id int primary key, name varchar(20), email varchar(30));
    
    -- 创建一个索引名为 idx_name 的索引
    create index idx_name on user10(name);
    

2.普通索引特点

  • 一个表中可以有多个普通索引,普通索引在实际开发中用的比较多
  • 如果某列需要创建索引,但是该列有重复的值,那么我们就应该使用普通索引

4.创建全文索引(了解即可)

  • 当对文章字段或有大量文字的字段进行检索时,会使用到全文索引
  • MySQL提供全文索引机制,但是有要求,要求表的存储引擎必须是MyISAM,而且默认的全文索引支持英文,不支持中文
    • 如果对中文进行全文检索,可以使用sphinx的中文版(coreseek)
    CREATE TABLE articles (
    	id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    	title VARCHAR(200),
    	body TEXT,
    	FULLTEXT (title,body)
    )engine=MyISAM;
    
    INSERT INTO articles (title,body) VALUES
    	('MySQL Tutorial','DBMS stands for DataBase ...'),
    	('How To Use MySQL Well','After you went through a ...'),
    	('Optimizing MySQL','In this tutorial we will show ...'),
    	('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
    	('MySQL vs. YourSQL','In the following database comparison ...'),
    	('MySQL Security','When configured properly, MySQL ...');
    
  • 查询有没有database数据
    • 如果使用如下查询方式,虽然查询出数据,但是没有使用到全文索引
    mysql> select * from articles where body like '%database%';
    +----+-------------------+------------------------------------------+
    | id | title             | body                                     |
    +----+-------------------+------------------------------------------+
    | 1  | MySQL Tutorial    | DBMS stands for DataBase ...             |
    | 5  | MySQL vs. YourSQL | In the following database comparison ... |
    +----+-------------------+------------------------------------------+
    
  • 可以用explain工具看一下,是否使用到索引
    mysql> explain select * from articles where body like '%database%'\G
    *************************** 1. row ***************************
    id: 1
    select_type: SIMPLE
    table: articles
    type: ALL
    possible_keys: NULL
    key: NULL <== key为null表示没有用到索引
    key_len: NULL
    ref: NULL
    rows: 6
    Extra: Using where
    
  • 如何使用全文索引呢?
    mysql> SELECT * FROM articles WHERE MATCH (title,body) AGAINST ('database');
    +----+-------------------+------------------------------------------+
    | id | title             | body                                     |
    +----+-------------------+------------------------------------------+
    | 5  | MySQL vs. YourSQL | In the following database comparison ... |
    | 1  | MySQL Tutorial    | DBMS stands for DataBase ...             |
    +----+-------------------+------------------------------------------+
    
  • 通过explain来分析这个sql语句
    mysql> explain SELECT * FROM articles WHERE MATCH (title,body) AGAINST ('database')\G
    *************************** 1. row ***************************
    id: 1
    select_type: SIMPLE
    table: articles
    type: fulltext
    possible_keys: title
    key: title <= key用到了title
    key_len: 0
    ref:
    rows: 1
    Extra: Using where
    

5.索引操作

1.查询索引

  • 第一种方法:show keys from 表名;
    mysql> show keys from goods\G
    *********** 1. row ***********
    Table: goods <= 表名
    Non_unique: 0 <= 0表示唯一索引
    Key_name: PRIMARY <= 主键索引
    Seq_in_index: 1
    Column_name: goods_id <= 索引在哪列
    Collation: A
    Cardinality: 0
    Sub_part: NULL
    Packed: NULL
    Null:
    Index_type: BTREE <= 以B+树形式的索引
    Comment:
    
  • 第二种方法:show index from 表名;
  • 第三种方法(信息比较简略):desc 表名

2.删除索引

  • 第一种方法
    • 删除主键索引alter table 表名 drop primary key;
  • 第二种方法
    • 删除其他索引alter table 表名 drop index 索引名;
    • 索引名就是show keys from 表名中的 Key_name 字段
    mysql> alter table user10 drop index idx_name;
    
  • 第三种方法:drop index 索引名 on 表名
    mysql> drop index name on user8;
    

3.索引创建原则

  • 比较频繁作为查询条件的字段应该创建索引
  • 唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件
  • 更新非常频繁的字段不适合作创建索引
  • 不会出现在where子句中的字段不该创建索引

4.其他概念(可自行了解)

  • 复合索引
  • 索引最左匹配原则
  • 索引覆盖

6.思考

  • 创建索引能提高数据插入的性能?
    • 错的,数据插入会造成索引更新,索引更新操作也是需要消耗时间性能
  • 索引一定会提高查询效率?
    • 错的,索引需要在条件中命中该索引列才行,没有命中就不会提高查询效率,某些条件下不会使用索引
      • 比如:name列创建了索引,但是使用where name is null,就不会使用该列的索引(因为索引没有保存null的信息)
  • 39
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 22
    评论
MySQL索引是一种数据结构,用于提高数据库的性能。它似于书籍的索引,可以帮助快速定位到特定的数据记录。 当你在数据库表中创建一个索引时,MySQL会为该列(或多列)创建一个数据结构,该结构包含索引和指向实际数据行的指针。这样,在查询时,MySQL可以使用索引来快速定位到匹配特定条件的数据行,而不需要遍历整个表。 要讲解MySQL索引,可以按照以下步骤: 1. 确定哪些列需要创建索引:通常,你会在经常用作查询条件的列上创建索引。例如,经常用于WHERE或JOIN语句的列,或者经常用于排序和分组的列。 2. 选择合适的索引类型:MySQL支持多种索引类型,如B树索引、哈希索引全文索引等。你需要根据具体需求选择合适的索引类型。 3. 创建索引:使用CREATE INDEX语句在表上创建索引。例如,创建一个名为idx_name的B树索引:`CREATE INDEX idx_name ON table_name (column_name);` 4. 了解索引使用的原则:索引并非越多越好,因为每个索引都需要占用存储空间,并且在插入、更新和删除操作时会有一定的性能损耗。因此,需要权衡索引的数量和性能影响。 5. 监控和优化索引:定期检查索引的使用情况,根据实际情况进行调整和优化。可以使用EXPLAIN语句来分析查询计划,查看是否正确使用了索引。 总之,MySQL索引可以显著提高查询性能,但需要根据具体情况来选择和使用索引,并进行适当的监控和优化。
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DieSnowK

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值