Mysql 中创建索引和索引的使用问题
在数据库中合理的使用索引是提升mysql数据库的一种高效和快捷的方式,但是在索引的使用上在我的使用中发现有很多坑,因为自己之前没有认识到,所以来总结一下
索引的介绍
索引是一种特殊的文件,其中包含着对数据表中的所有记录的引用指针
添加索引的条件
字段中存储的内容重复性不能过高,比如性别,颜色等这些可区分性很低的字段
字段会经常性的用作查询语句。 因为创建索引也是需要存储的空间的,而且创建了索引会造成insert等语句的速度变慢
字段更新的斌率不高的字段适合添加索引。数据的更新会带来索引的更新。
索引的类型
普通索引 :
key。唯一的作用就是加快查询的速度主键索引 :
primary key。字段具备唯一性 一张数据表中只有一个唯一索引 :
unique key。联合索引 :
key(a,b,c)。外键索引 : 在我现在的认识中,就是用来维护数据表之间的相关性的,并且会导致数据的写入等操作的速度过慢,所以。。好像没啥用(对于较大的项目)
全文索引 :
FULLTEXT(column1, column2)mysql5.6以前的InnoDB表不支持。使用:WHERE MATCH(column) AGAINST('search_content')
索引在使用上的注意点
索引字段上使用
WHERE DAY(column)='' 或WHERE column*2=100这种运算,索引不会被使用到在索引的字段上 使用
NOT IN,<>,!=这些运算符的时候,执行explain会使用到索引,但是这些操作是不被推崇的,因为就算是用到了索引速度也不会很快.而且在mysql的5.6版本以前这种方式就算执行explain操作也是是用不到索引的在索引字段上使用
like或regexp操作的时候,%的通配符不能放在要查找的字符串的左侧(可以想象使用索引的时候就是在查字典,比如想要找到'mysql'这个单词,需要从m开始,然后是y,所以查询的顺序就是从左往右的)关于联合索引的一些注意事项:
如果给一张表添加的一组联合索引如下:
key(name,email,age),mysql在添加联合索引的时候以‘最左前缀’的形式进行索引的添加,那么在进行查询select *的时候[name] [name,email] [name,email,age]这三组查询条件都是可以使用到这个组合索引的,但是这并不是重点如果现在使用
explain select * from table where age=11会发现索引并没有被使用到。 可是执行explain select name,email from table where age=11.会发现这个索引被使用到了。 这种方式叫做索引覆盖,在执行explain语句的时候,会发现extra一栏中卫'Using Index',如果存储引擎使用的是InnoDB,二级索引也存储了primary key的值,如果用过索引去访问primary key的值,也可以访问到
还有就是 关于添加联合索引还是单列索引的问题。如果字段都被添加成单列的索引,相比于联合索引的话,会增加数据库的IO的等待
索引的确可以加快mysql在查询时候的速度。但是在数据进行新增及更新等操作的时候,也需要对应的维护索引关系(但是也有配置可以在数据:DELAY_KEY_WRITE,不深入展开)
在使用多个条件进行数据的查询的时候,有网上的很多说法都是mysql中单次sql的查询只能使用到一个索引(这个是错误的!!) 一条sql语句,针对一张表的查询,多个条件之间使用
and拼接的话,索引在mysql内部会被执行 union的操作,索引是可以使用到的! 但是!如果条件之间使用or进行条件的拼接的话,那么如果想要该语句的索引有效就必须保证每个被or连接的条件都可以使用到索引。
索引的长度
比如果我现在想要给 用户表的用户家庭住址字段添加索引,该字段:address 的类型为varchar(255) ,对整个字段建立索引的话肯定是不合理的,这个时候需要为该字段的前n个值建立索引。可以使用 select count(distinct substring(字段,1,结束位置)) from 表
对比一下表中的总数据看一下该n值得选择性,用来确定索引的长度
Mysql 中创建索引和索引的使用问题的更多相关文章
- Mysql中主键与索引
摘自: https://www.cnblogs.com/wicub/p/5898286.html 一.什么是索引?索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.如果没 ...
- MySQL如何创建一个好索引?创建索引的5条建议【宇哥带你玩转MySQL 索引篇(三)】
MySQL如何创建一个好索引?创建索引的5条建议 过滤效率高的放前面 对于一个多列索引,它的存储顺序是先按第一列进行比较,然后是第二列,第三列...这样.查询时,如果第一列能够排除的越多,那么后面列需 ...
- mysql 中创建存储过程
mysql中创建存储过程和存储函数虽相对其他的sql语言相对复杂,但却功能强大,存储过程和存储函数更像是一种sql语句中特定功能的一种封装,这种封装可以大大简化外围调用语句的复杂程度. 首先以表emp ...
- 在MySQL中创建实现自增的序列(Sequence)的教程
这篇文章主要介绍了在MySQL中创建实现自增的序列(Sequence)的教程,分别列举了两个实例并简单讨论了一些限制因素,需要的朋友可以参考下 项目应用中,曾有以下一个场景: 接口中要求发送一个int ...
- EF Core使用CodeFirst在MySql中创建新数据库以及已有的Mysql数据库如何使用DB First生成域模型
官方教程:https://docs.microsoft.com/en-us/aspnet/core/data/?view=aspnetcore-2.1 使用EF CodeFirst在MySql中创建新 ...
- C# 利用mysql.data 在mysql中创建数据库及数据表
C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...
- mysql中创建函数时报错信息
报错信息如下 ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its ...
- 高性能mysql:创建高性能的索引
本文系阅读<高性能MySQL>,Baron Schwartz等著一书中第五章 创建高性能的索引的笔记,索引是存储引擎用于快速找到记录的一种数据结构. 索引对于良好的性能非常关键,尤其是当表 ...
- SqlServer中创建非聚集索引和非聚集索引
聚集索引与非聚集索引,其实已经有很多的文章做过详细介绍. 非聚集索引 简单来说,聚集索引是适合字段变动不大(尽可能不出现Update的字段).出现字段重复率小的列,因为聚集索引是对数据物理位置相同的索 ...
随机推荐
- wepy - 与原生有什么不同(slot插槽)
wepy官方文档是这样介绍的 简单描述就是: index.wpy:子组件 panel.wpy:父组件 1.slot是内容分发的占位符 2.slot父组件在子组件使用时,名称必须一致 3.slot子组件 ...
- Yahoo团队总结的关于网站性能优化的经验(转)
英文原文:http://developer.yahoo.com/performance/rules.html 中文原文:http://www.ha97.com/2710.html 1.尽量减少HTTP ...
- Oracle体系结构一(学习笔记)
总体结构分为三个部分:SGA,PGA,FILE文件 按功能分: 存储结构 存储结构对应关系 主要文件: 数据文件: 每个数据文件只与一个数据库相关联 一个表空间可以包含一个或者多个数据文件 一个数 ...
- 栈的应用实例——平衡符号
检查().[].{}是否配对. /* stack_balance_symbol */ #include "stack.h" #include <stdio.h> #in ...
- JDK目录结构和文件作用介绍
要想深入了解Java必须对JDK的组成, 本文对JDK6里的目录做了基本的介绍,主要还是讲解了下JDK里的各种可执行程序或工具的用途Java(TM) 有两个平台 JRE 运行平台,包括Java虚拟机, ...
- SQL入门教程
SQL SELECT DISTINCT 语句 在表中,可能会包含重复值.这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值. 关键词 DISTINCT 用于返回唯一不同的值. 语法 ...
- 修改终端下vim的PopupMenu选种项的背景颜色
我平常比较喜欢使用终端下的 VIM,最方便的就是随时可以使用ctrl+z切换到终端下执行命令, 然后再通过fg切换回 VIM.如果再有个透明效果,那就更赞了.不过最近换了一个配色ron 后, 有个比较 ...
- sp_trace_setevent sqlserver跟踪事件及列
常用几个事件 10 RPC:Completed12 SQL:BatchCompleted43 SP:Completed sp_trace_setevent sp_trace_setevent [ @t ...
- Eclipse 如何创建Web项目
Eclipse 如何创建Web项目 CreateTime--2018年3月8日16:43:33 Author:Marydon 第一步: 右键-->New-->Dynamic Web P ...
- 设置Linux-Centos6.5字符集
登录腾讯云的服务,发现不支持中文字符.草蛋疼.... 01.查看Linux当前语言 echo $LANG C #C代表英文环境 ASCII 编码格式,通杀很多问题(乱码) 02.查看系统支持的 ...