mysql索引基本知识(MySql索引使用策略分析)
mysql索引基本知识
MySql索引使用策略分析MySql索引
索引优点
1.可以通过建立唯一索引或者主键索引,保证数据的唯一性.
2.提高检索的数据性能
3.在表连接的连接条件 可以加速表与表直接的相连
4.建立索引,在查询中使用索引 可以提高性能
索引缺点
1.在创建索引和维护索引 会耗费时间,随着数据量的增加而增加
2.索引文件会占用物理空间,除了数据表需要占用物理空间之外,每一个索引还会占用一定的物理空间
3.当对表的数据进行 INSERT,UPDATE,DELETE 的时候,索引也要动态的维护,这样就会降低数据的维护速度,
(建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引,索引文件的会膨胀很快)。
使用索引需要注意的地方
1.在经常需要搜索的列上,可以加快索引的速度
2.主键列上可以确保列的唯一性
3.在表与表的而连接条件上加上索引,可以加快连接查询的速度
4.在经常需要排序(order by),分组(group by)和的distinct 列上加索引 可以加快排序查询的时间, (单独order by 用不了索引,索引考虑加where 或加limit)
5.在一些where 之后的 < <= > >= BETWEEN IN 以及某个情况下的like 建立字段的索引(B-TREE)
6.like语句的 如果你对nickname字段建立了一个索引.当查询的时候的语句是 nickname lick '%ABC%' 那么这个索引讲不会起到作用.而nickname lick 'ABC%' 那么将可以用到索引
7.索引不会包含NULL列,如果列中包含NULL值都将不会被包含在索引中,复合索引中如果有一列含有NULL值那么这个组合索引都将失效,一般需要给默认值0或者 ' '字符串
8.使用短索引,如果你的一个字段是Char(32)或者int(32),在创建索引的时候指定前缀长度 比如前10个字符 (前提是多数值是唯一的..)那么短索引可以提高查询速度,并且可以减少磁盘的空间,也可以减少I/0操作.
9.不要在列上进行运算,这样会使得mysql索引失效,也会进行全表扫描
10.选择越小的数据类型越好,因为通常越小的数据类型通常在磁盘,内存,cpu,缓存中 占用的空间很少,处理起来更快
什么情况下不创建索引
1.查询中很少使用到的列 不应该创建索引,如果建立了索引然而还会降低mysql的性能和增大了空间需求.
2.很少数据的列也不应该建立索引,比如 一个性别字段 0或者1,在查询中,结果集的数据占了表中数据行的比例比较大,mysql需要扫描的行数很多,增加索引,并不能提高效率
3.定义为text和image和bit数据类型的列不应该增加索引,
4.当表的修改(UPDATE,INSERT,DELETE)操作远远大于检索(SELECT)操作时不应该创建索引,这两个操作是互斥的关系
以上就是MySql索引使用策略分析的详细内容,更多关于MySQL 索引的资料请关注开心学习网其它相关文章!
原文链接:https://www.cnblogs.com/CoolYYD/p/13704593.html
- mysql怎么设置某个字段默认值(MySQL表字段时间设置默认值)
- mysql锁机制及原理(MySQL锁阻塞的深入分析)
- mysql数据库基本增删改查基本语句(MySQL表的增删改查基础教程)
- mysql的decimal类型(MySQL数据类型DECIMAL用法详解)
- mysqldump 命令详解(mysqldump你可能不知道的参数)
- mysql读写分离怎么实现的(详解MySQL主从复制及读写分离)
- mysql url连接参数配置(浅谈Mysql连接数据库时host和user的匹配规则)
- mac版本php环境搭建(在Mac OS X中配置Apache+PHP+MySQL运行环境的详细步骤)
- 织梦源码安装数据库怎么填(Mysql修改端口号 织梦DedeCMS设置教程)
- mysql用户删除了如何设置(MySQL两种删除用户语句的区别delete user和drop user)
- mysql连接数与缓存(Mysql连接数设置和获取的方法)
- mysql 用户权限配置(详解MySQL 用户权限管理)
- mysql查询逗号分割字符串(MySQL 字符串拆分实例无分隔符的字符串截取)
- mysql修改复杂密码设置(MySQL修改密码的几种方式)
- mysql缓存和redis查询效率(浅谈MySQL与redis缓存的同步方案)
- mysql突然报错206无法连接(详解MySQL连接挂死的原因)
- 爱情可以当饭吃吗(爱情能当饭吃吗)
- Top 3 JSHS《运动与健康科学 英文 》跻身SCI体育学期刊世界前三(Top3JSHS运动与健康科学)
- 体坛传媒LOGO全新升级,多元发展迈出坚实步伐(体坛传媒LOGO全新升级)
- 超撩人治愈的绝美水彩,原来出自她之手 一笔一画令无数人沉醉(超撩人治愈的绝美水彩)
- 新手的勾线(新手的勾线)
- ()
热门推荐
- spring boot 如何启动tomcat(传统tomcat启动服务与springboot启动内置tomcat服务的区别推荐)
- pandas 导入数据库(详解pandas的外部数据导入与常用方法)
- mysql长连接释放和不释放的问题(解决MySQL存储时间出现不一致的问题)
- springboot vue 异地登录(vue+springboot实现登录验证码)
- pandas 比较两个表数据是否相同(浅谈pandas筛选出表中满足另一个表所有条件的数据方法)
- mysql常用优化方法(理解MySQL查询优化处理过程)
- sqlserver分表后如何查询(SQL Server中row_number分页查询的用法详解)
- react代码质量检查(react如何实现一个密码强度检测器详解)
- css 页面加载样式(如何只在IE上加载CSS样式表)
- html5文档的基本结构及必要的注释(关于HTML5+ API plusready的兼容问题)