SQL索引(INDEX)
不使用索引,数据库引擎将遍历整个表。
从表面上看,索引类似于书的目录,在没有目录的情况下,要从书中查找某项内容就必须阅读全文,而有了目录之后,通过页码就可以很快定位到相关内容。
从本质上看,索引是根据表的一个或者多个字段生成的子表,该子表中的数据已经进行了排序。子表除了包含指定字段中的数据,还包含一个 rowid 列,用于存储当前记录在原始表中的位置。用户无法看到索引,它只是用来加快查询速度。
为了提高查询效率,便于后期维护,索引都是基于某种数据结构而创建的,比如 B+ 树、B- 树、位图等。
索引的使用成本
在表中插入、修改或者删除数据时,数据库引擎也必须维护索引,以保持索引和原始表的同步;也就是说,使用索引是有额外开销的。不适的索引,或者过多的索引,都会降低插入、修改和删除数据的效率。索引还会占用磁盘空间,增加 I/O 成本,过多的索引甚会增加碎片。
鉴于以上两点,使用索引时应该遵循以下几条原则:
仅在被频繁检索的字段上创建索引。
针对大数据量的表创建索引,而不是针对只有少量数据的表创建索引。
通常来说,经常查询的记录数目少于表中总记录数据的 15% 时,可以创建索引。这个比例并不,它与全表扫描速度成反比。
尽量不要在有大量重复值得字段上建立索引,比如性别字段、季度字段等。
语法
在某个字段上创建索引的基本语法如下:
index_name 是索引的名字,以后在删除索引时会用到。CREATE INDEX index_name
ON table_name ( column1, column2.....);
示例
使用 SQL 语句创建一个包含七列的 website 表:
CREATE TABLE website (
id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(20) NOT NULL,
url VARCHAR(30),
age TINYINT UNSIGNED NOT NULL,
alexa INT UNSIGNED NOT NULL,
uv FLOAT DEFAULT '0',
country CHAR(3) NOT NULL,
PRIMARY KEY (`id`)
);
现在您可以针对 name 字段创建索引,用以提高检索姓名时的效率,如下所示:
CREATE INDEX myIndex
ON website(name);
myIndex 是索引的名字。
删除索引
删除索引请使用下面的 SQL 语句:
ALTER TABLE website
DROP INDEX myIndex;
- 随机文章
- 核心危机(核心危机魔石合成攻略)
- 儿童教育文章(儿童教育)
- 光遇花手先祖位置(安卓光遇手花先祖)
- 广州4a广告公司(广州4a广告公司创意总监年薪)
- 抖音卡(抖音卡顿怎么解决)
- xboxones(xboxone手柄怎么配对主机)
- 兵马俑(兵马俑介绍和历史背景)
- 陈武简历
- 帆船比赛(帆船比赛视频)
- 海猫鸣泣之时游戏(海猫鸣泣之时游戏在哪玩)
- 韩国媳妇和小雪(韩国媳妇和小雪的父亲工资是多少)
- 儋州市第二中学(儋州市第二中学录取分数线)
- 地球日主题(2020年世界地球日主题)
- 和柳亚子(和柳亚子先生于田)
- 冰客(冰客果汁)
- yy魔兽(yy魔兽世界)
- 国外成人游戏(国外成人游戏注册需要visa信用卡)
- 充值卡代理(充值卡代理加盟)
- 拆奶罩
- 郭妮小说(恶魔的法则郭妮小说)
- 东天目山(东天目山景区)
- 杭同(杭同培训中心怎么样)
- 蝙蝠给人类的一封信(蝙蝠给人类的一封信)
- 大松电饭煲(美的大松电饭煲)
- 服饰加盟(服饰加盟店招商)
- 疯狂填字(疯狂填字5)
- 观音普门品(观音普门品念诵全文)
- 河北省大运会(河北省大运会时间)
- 哈利波特官网(哈利波特官网在哪里)
- 骇客神条(骇客神条怎么辨别真假)
