索引-mysql
什么是索引?
  宏观来说,索引是一种检索工具,目录也是一种检索工具,但是两者是有区是别的
	  官方概念是说:
	  索引与目录的根本区别就在于著录的对象不同,目录所著录的是一个
	  完整的出版单位,如一种图书、一种期刊等,而索引所著录的则是完整的出版物的
	  某一部分、某一观点、某一知识单元、一种期刊等;
	  简单来说,
	  目录能定位到一本书,而索引能定位到这本书的一段内容或是更细的一行文字。
  在关系型数据库中,索引是一个特有术语:
	  在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,
	  它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。
	  简单来说,
	  有了索引,可以通过索引找到指定列的指定记录
索引的四大作用
  ①更快读取数据(至于为什么能加快速度,可参考博文:(转)深入浅出数据库索引原理 | (转)MySql数据库索引原理);
	  ②保证数据记录的唯一性(唯一索引确保的);
	  ③实现表与表之间的参照完整性;
		    ###	这里穿插一些关于数据库完整性的概念(参考百度文库文档:(转)文库文档):
			      1)参照完整性
				        作用:保证数据之间的完整性;
				        实现:在数据库设计器中设计表之间的联系时,要在父表中建立主索引或候选索引,在子表中建立普通索引,
        然后通过父表的主索引(候选索引)和子表的普通索引建立起两个表之间的联系。
			      2)实体完整性				
				        作用:保证表中记录唯一的特性;
				        实现:主关键字建立主索引/唯一索引;
			      3)域完整性
				        作用:保证表中字段的正确性;
				        实现:通过限定字段的类型、字段(表)有效性规则、默认值来实现;
	  ④在使用ORDER by、group by子句进行数据检索时,利用索引可以减少排序和分组的时间;
索引的优缺点
优点:
  1、大大加快数据的检索速度;
	  2、创建唯一性的索引,保证数据库表中每一行数据的唯一性;
	  3、加速表与表之间的连接;
	  4、在使用分组和排序子句进行数据检索时,可以显著减少查询中分组和排序的时间;
缺点:
  1、索引需要占用物理空间;
	  2、当对表中的数据进行增加、删除和修改的时候,索引也要有动态的维护,降低了数据的维护速度;
索引分类
普通索引
最基本的索引类型,没有唯一性之类的限制。
//创建索引
create index my_index on my_table(username(15));
//修改索引
alter table my_table add index my_index(my_column);
//创建表时创建索引
create table my_table(
id int not null,
username varchar(15) not null,
index my_index (username(15))
);
//删除索引
drop index my_index;
唯一索引(关键词:unique)
唯一索引是不允许其中任何两行具有相同索引值的索引(与主键索引的区别是唯一索可允许为空而主键索引不能)。
//创建唯一索引
create unique my_index on my_table(username(15));
//修改唯一索引
alter table my_table add unique my_index(my_column);
//创建表时创建唯一索引
create table my_table(
id int not null,
username varchar(15) not null,
unique my_index (username(15))
);
//删除索引
drop index my_index;
//显示索引信息
show index from my_table;
主键索引
在数据库关系图中为表定义主键将自动创建主键索引,主键索引是唯一索引的特定类型(主键索引=唯一索引+非空);
候选索引
与主索引一样要求字段值的唯一性,并决定了处理记录的顺序。
聚集索引(关键词:clustered)
也称为聚簇索引,在聚集索引中,表中行的物理顺序与键值的逻辑(索引)顺序相同。一个表只能包含一个聚集索引;例如时间、年份、这类可以排序的列就可用聚集索引;
非聚集索引(关键词:nonclustered)
也叫非簇索引,在非聚集索引中,数据库表中记录的物理顺序与索引顺序可以不相同。一个表中只能有一个聚集索引,但表中的每一列都可以有自己的非聚集索引;
什么地方需要建索引(参考原文:(转)Mysql哪些地方需要建立索引)
1、表的主键、外键必须有索引;
2、数据量超过300的表应该有索引;
3、经常与其他表进行连接的表,在连接字段上应该建立索引;
4、经常出现在where子句中的字段,特别是大表的字段,应该建立索引;
5、索引应该建立在选择性高的字段上;
6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引;
7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替;
a、正确选择复合索引中的主列字段,一般是选择性较好的字段;
b、复合索引的几个字段是否经常以AND方式出现在Where子句中?单字段查询是否极少甚至没有?如果是,则可以建立复合索引;否则考虑单字段索引;
c、如果复合索引中包含的字段经常单独出现在where子句中,则分解为多个单字段索引;
d、如果复合索引中包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的字段;
e、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引;
8、频繁进行数据操作的表,不要建立太多的索引;
9、删除无用的索引,避免对执行计划造成负面影响;
索引优化
暂无,详解可参考:(转)MySQL 索引及优化实战
索引-mysql的更多相关文章
- mysql 添加索引 mysql 创建索引
		1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引 ... 
- macOS安装Solr并索引MySQL
		安装 Java 语言的软件开发工具包 brew cask install java 或者在 Oracle官网 中选择 Mac 版本 jdk-8u111-macosx-x64.dmg 下载并安装. 安装 ... 
- 真分布式SolrCloud+Zookeeper+tomcat搭建、索引Mysql数据库、IK中文分词器配置以及web项目中solr的应用(1)
		版权声明:本文为博主原创文章,转载请注明本文地址.http://www.cnblogs.com/o0Iris0o/p/5813856.html 内容介绍: 真分布式SolrCloud+Zookeepe ... 
- mysql 添加索引 mysql 如何创建索引
		1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引 ... 
- 使用Solr索引MySQL数据
		环境搭建 1.到apache下载solr,地址:http://mirrors.hust.edu.cn/apache/lucene/solr/ 2.解压到某个目录 3.cd into D:\Solr\s ... 
- 使用sphinx索引mysql数据
		数据库表如下 mysql> select * from tb_account; +----+-------+------+ | id | name | age | +----+-------+- ... 
- solr5.5索引mysql数据(新手总结)
		一 solr5.5环境部署到Eclipse(luna版) solr部署参见:http://blog.csdn.net/csmnjk/article/details/64121765 二 Ik分词器设置 ... 
- 为什么用B+树做索引&MySQL存储引擎简介
		索引的数据结构 为什么不是二叉树,红黑树什么的呢? 首先,一般来说,索引本身也很大,不可能全部存在内存中,因此索引往往以索引文件的方式存在磁盘上.然后一般一个结点一个磁盘块,也就是读一个结点要进行一次 ... 
- 索引-mysql索引创建、查看、删除及使用示例
		mysql索引创建.查看.删除及使用示例 1.创建索引: ALTER TABLE用来创建普通索引.UNIQUE索引或PRIMARY KEY索引. ALTER TABLE table_name ADD ... 
随机推荐
- SpringCloud(4)---Ribbon服务调用,源码分析
			SpringCloud(4)---Ribbon 本篇模拟订单服务调用商品服务,同时商品服务采用集群部署. 注册中心服务端口号7001,订单服务端口号9001,商品集群端口号:8001.8002.800 ... 
- IdentityServer4之Client Credentials(客户端凭据许可)
			IdentityServer4之Client Credentials(客户端凭据许可) 参考 项目创建:0_overview,1_client_credentials 概念:客户端凭据许可 认证服务端 ... 
- C#版 - Leetcode 201. 数字范围按位与(bitwise AND) - 题解
			C#版 - Leetcode 201. 数字范围按位与(bitwise AND) - 题解 在线提交: https://leetcode.com/problems/bitwise-and-of-num ... 
- Android--使用Camera拍照
			前言 在开发Android应用的时候,如果需要调用摄像头获取拍摄的照片,除了通过Intent调用系统现有相机应用拍摄照片之外,还可以通过直接调用Camera硬件去去获取摄像头拍摄的照片.本篇博客将讲解 ... 
- [java]static关键字的四种用法
			在java的关键字中,static和final是两个我们必须掌握的关键字.不同于其他关键字,他们都有多种用法,而且在一定环境下使用,可以提高程序的运行性能,优化程序的结构.下面我们先来了解一下stat ... 
- 第14章 添加JavaScript客户端 - Identity Server 4 中文文档(v1.0.0)
			本快速入门将展示如何构建基于浏览器的JavaScript客户端应用程序(有时称为" SPA "). 用户将登录IdentityServer,使用IdentityServer发出的访 ... 
- Python批量修改寄存器的值
			在写代码过程中,我们修改代码中寄存器的值,但是有时寄存器的数据较多,手动修改容易出现错误而且花费的时间长 这是一段寄存器的配置值: 0x00, 0x34 0x35, 0x25 0x10, 0xd4 ... 
- Java 由浅入深GUI编程实战练习(二)
			一,项目简介 1.利用Java GUI 绘制图像界面,设置整体布局 2.编写一个随机数生成1~100的随机数 3.编写一个验证类,用于验证用户输入值与生成随机数是否相等并记录用户猜测次数,当用户猜测成 ... 
- Bootstrap 实战之响应式个人博客 (二)
			阅读本博文前请参考:Bootstrap 实战之响应式个人博客 (一) 一.博客 1.结构 整体博客详情页的结构共包括四部分: 导航栏 博客主体内容 右侧栏:全局搜索框,广告位,推荐阅读 页尾 其中导航 ... 
- 解决No 'Access-Control-Allow-Origin' header is present on the requested resource.跨域问题(后台(java)解决方法)
			附:前端常见跨域解决方案(全) 跨域错误 解决方法 在后台写一个过滤器来改写请求头 附上一个前端不知所以然的后台java代码: public class CorsFilter implements F ... 
