mysql索引怎么用


本文摘自PHP中文网,作者(*-*)浩,侵删。

MySQL索引的概念

索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度。上述SQL语句,在没有索引的情况下,数据库会遍历全部200条数据后选择符合条件的;而有了相应的索引之后,数据库会直接在索引中查找符合条件的选项。如果我们把SQL语句换成“SELECT * FROM article WHERE id=2000000”,那么你是希望数据库按照顺序读取完200万行数据以后给你结果还是直接在索引中定位呢?(注:一般 数据库默认都会为主键生成索引)。

推荐课程:MySql教程。

索引分为聚簇索引和非聚簇索引两种,聚簇索引是按照数据存放的物理位置为顺序的,而非聚簇索引就不一样了;聚簇索引能提高多行检索的速度,而非聚簇索引对于单行的检索很快。

MySQL索引的类型

1. 普通索引

这是最基本的索引,它没有任何限制,比如上文中为title字段创建的索引就是一个普通索引,MyIASM中默认的BTREE类型的索引,也是 我们大多数情况下用到的索引。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

?C直接创建索引

CREATE INDEX index_name ON table(column(length))

?C修改表结构的方式添加索引

ALTER TABLE table_name ADD INDEX index_name ON (column(length))

?C创建表的时候同时创建索引

CREATE TABLE `table` (

`id` int(11) NOT NULL AUTO_INCREMENT ,

`title` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,

`content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL ,

`time` int(10) NULL DEFAULT NULL ,

PRIMARY KEY (`id`),

INDEX index_name (title(length))

)

?C删除索引

DROP INDEX index_name ON table

2. 唯一索引

与普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值(注意和主键不同)。如果是组合索引,则列值的组合必须唯一,创建方法和普通索引类似。

1

2

3

4

5

6

7

8

9

10

11

12

?C创建唯一索引

CREATE UNIQUE INDEX indexName ON table(column(length))

?C修改表结构

ALTER TABLE table_name ADD UNIQUE indexName ON (column(length))

?C创建表的时候直接指定

CREATE TABLE `table` (

`id` int(11) NOT NULL AUTO_INCREMENT ,

`title` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,

`content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL ,

`time` int(10) NULL DEFAULT NULL ,

PRIMARY KEY (`id`),

UNIQUE indexName (title(length))

以上就是mysql索引怎么用的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

我所理解的mysql之四:事务、隔离级别及mvcc

比较详细的mysql字段类型说明

centos下实现mysql远程登录

mysql如何跳过权限进行操作的步骤

mysql date如何插入null

了解mysql中的外键作用

mysql中如何批量删除数据

mysql语句查看各个数据库占用空间的方法(附代码)

mysql 教程之数据库

mysql中使用binlog时binlog格式的选择

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...