索引-mysql索引创建、查看、删除及使用示例
mysql索引创建、查看、删除及使用示例
1.创建索引:
ALTER TABLE用来创建普通索引、UNIQUE索引或PRIMARY KEY索引。
ALTER TABLE table_name ADD INDEX index_name (column_list)
ALTER TABLE table_name ADD UNIQUE (column_list)
ALTER TABLE table_name ADD PRIMARY KEY (column_list)
CREATE INDEX可对表增加普通索引或UNIQUE索引。
CREATE INDEX index_name ON table_name (column_list)
CREATE UNIQUE INDEX index_name ON table_name (column_list)
2.删除索引:
DROP INDEX index_name ON talbe_name
ALTER TABLE table_name DROP INDEX index_name
ALTER TABLE table_name DROP PRIMARY KEY
3.查看索引:
mysql> show index from tblname;
mysql> show keys from tblname;
SQL代码在线格式化美化工具:http://tools.jb51.net/code/sqlcodeformat
4.索引的使用场景:
===========================以下为索引的使用场景(sqlserver)=================================
[1].漫谈数据库索引
1.创建表并插入数据
在Sql Server2008中创建测试数据库Test,接着创建数据库表并插入数据,sql代码如下:
USE Test
IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME = 'emp_pay')
DROP TABLE emp_pay
GO
USE Test
IF EXISTS (SELECT name FROM sys.indexes
WHERE name = 'employeeID_ind')
DROP INDEX emp_pay.employeeID_ind
GO
USE Test
GO
CREATE TABLE emp_pay
(
employeeID int NOT NULL,
base_pay money NOT NULL,
commission decimal(2, 2) NOT NULL
)
INSERT emp_pay
VALUES (1, 500, .10)
INSERT emp_pay
VALUES (2, 1000, .05)
INSERT emp_pay
VALUES (6, 800, .07)
INSERT emp_pay
VALUES (5, 1500, .03)
INSERT emp_pay
VALUES (9, 750, .06)
执行完上述sql代码以后我们会发现在Test数据库中多出了一张emp_pay表,数据库表的内容如下图所示:
2.无索引查找
从上图我们可以看出数据库中存储的数据排列顺序与我们插入的先后顺序一致。接下来我们查询employeeID=5的字段,执行如下sql代码:
USE Test
SELECT * FROM emp_pay where employeeID=5
在SQL SERVER MANAGEMENT STUDIO中我们点击“显示估计的查询计划”,会出现如下图所示的查询计划图:
其中表扫描的内容为:
3.创建索引
接下来我们为上述表添加聚集唯一索引,代码如下:
SET NOCOUNT OFF
CREATE UNIQUE CLUSTERED INDEX employeeID_ind
ON emp_pay (employeeID)
GO
在执行完上述创建索引的代码以后,我们再次查询emp_pay的数据内容,如下图所示:
从上图我们可以发现数据内容已经按照employeeID进行了排序。
我们继续执行前面关于employeeID=5的查询,点击“显示估计的执行计划”,出现如下图所示内容:
聚集索引查找的内容为:
总结:
当我们为数据库表中的某一个字段创建索引,并且在查询语句中where子句中用到这样一个字段,那么查询效率会有所提高,我们上述实验因为数据量的关系查询效率提高不明显。
补充
我们上面添加的索引是唯一聚集索引,因此当插入的数据在employeeID字段出现重复时会报错。假如我们在创建索引之前数据字段出现重复,那么就不能创建唯一索引。
创建索引以后的排序(PS:2012-5-28)
执行如下sql语句
update emp_pay set employeeID=7 where employeeID=1;
然后再次执行全表查询,我们发现查询结果如下所示:
只要我们更新了employeeID,那么最后的更新结果都会按照employeeID的值进行升序排序。这是因为我们在employeeID上创建了索引的缘故。
删除索引(PS:2012-6-4)
我们可以通过sql server management studio这个工具删除索引,也可以通过sql语句进行索引的删除,假设我们要求删除在前面创建的索引employeeID_ind,那么sql语句如下代码所示:
DROP INDEX employeeID_ind ON emp_pay;
最新文章
- hibernate笔记--缓存机制之 二级缓存(sessionFactory)和查询缓存
- js操纵css更改加载图片大小
- Codeforces Round #215 (Div. 2) B. Sereja and Suffixes
- K-邻近算法
- 从头学Android之Android布局管理:LinerLayout线性布局
- Dev gridView中设置自适应列宽和日期显示格式、金额的显示格式
- zookeeper-3.4.6安装
- Eat the Trees hdu 1693
- C/C++动态分配与释放内存的区别详细解析
- kettle新建资源库出错
- 长乐集训2012.7.11 happy(指针技巧的运用)
- 如何使用开源库,吐在VS2013发布之前,顺便介绍下V2013的新特性";Bootstrap";
- 6.如何使用jedis的线程池
- Matlab学习笔记(2)
- Core Graphics 和Quartz 2D的区别
- CSA Round #54 $\ $Voting
- python文件基本操作(读,写,追加)
- iOS开发中数据持久化
- Windows平台软件推荐:神器小工具(骨灰级)
- Hibernte
热门文章
- [cocos2dx笔记013]一个使用CCRenderTexture创建动态纹理显示数字的类
- Aizu - 2305 Beautiful Currency (二分 + DFS遍历)
- Node.js 博客实例(一)简单博客
- vc应用CPictureEx类(重载CStatic类)加载gif动画
- xBIM 基础07 创建WebBIM文件
- Elasticsearch之重要核心概念(cluster(集群)、shards(分配)、replicas(索引副本)、recovery(据恢复或叫数据重新分布)、gateway(es索引的持久化存储方式)、discovery.zen(es的自动发现节点机制机制)、Transport(内部节点或集群与客户端的交互方式)、settings(修改索引库默认配置)和mappings)
- 003.JMS概述
- MySQL学习(四)——外键
- windows2008 虚拟机64位的操作系统安装32位的应用程序
- 使用3ds Max制作卡通狗教程