MySQL学习【第八篇索引优化】
一.建立索引的原则(规范)
1.选择唯一性索引
只要可以创建唯一性索引的,一律创建唯一索引(因为速度快呀)
判断是否能创建唯一索引,用count(列名),count(distinct(列名))一样就能创建
2.如果该列重复值较多,则采用联合索引
3.为经常需要排序,分组,联合操作的字段建立索引,例如京东,淘宝那些产品就需要建立索引
4.为常作为查询字段的建立索引,比如你搜索的商品,它们基本就是做了索引的,而且不仅做了,还肯定加了缓存
5.如果是经常查询字段,重复值还特别多的,使用联合索引
6.字段值很长的,尽量使用前缀索引
7.限制索引的数目,索引不是每一列都要创建的,每个索引都要占用磁盘空间,创的越多,磁盘占用越大,修改表的时候,对索引的重构和更新非常麻烦还很慢,每次update都很麻烦,而且还浪费磁盘I/O
8.删除不常用的索引和不再使用的索引,减少索引对更新操作的影响,节省资源
二.优化sql语句
1.没有查询条件,或者查询条件没有建立索引(没查询条件就是全表扫描)
优化:添加查询条件,为查询条件创建索引
(在业务数据中,是没有全表扫描这种需求的,而且用户也不可能有权限去全表扫描,对用户体验是痛苦的,对服务器性能更是毁灭性打击,如果有人提出这种要求,拉出去祭天就是了!!!)
2.查询结果集原表中的大部分数据时(大概在25%以上时就将不走索引),添加limit限定
3.索引本身失效,数据不真实,对于表的内容更新过于频繁,有可能导致索引失效
怎么看是否失效呢,写个一定会走索引的语句的脚本,然后监控它
如果得到结果是失效的,删除索引,重新建立
4.查询条件使用函数在索引列上进行运算例如加减乘除,则不走索引(错误示范),如果你硬要秀操作则看(正确示范)
错误示范
select * from student where id-=; 正确示范
select * from student where id=+; 或者 select * from student where id=;
5.隐式转化导致的索引失效(一般都是开发犯的错误,祭天祭天!!!)
mysql> create table test (id int ,name varchar(),telnum varchar());
mysql> insert into test values(,'zs',''),(,'l4',),(,'w5',),(,'z4',);
mysql> explain select * from test where telnum=;
mysql> alter table test add index idx_tel(telnum);
mysql> explain select * from test where telnum=;
mysql> explain select * from test where telnum=;
mysql> explain select * from test where telnum='';
6. <> ,not in 不走索引(单独的>,<,in 有可能走,也有可能不走,和结果集有关,尽量结合业务添加limitor或in尽量改成union)
mysql> select * from tab where telnum <> '';
mysql> explain select * from tab where telnum <> '';
7.like "%_" 百分号在最前面不走索引
#走range索引扫描
EXPLAIN SELECT * FROM teltab WHERE telnum LIKE '31%';
#不走索引
EXPLAIN SELECT * FROM teltab WHERE telnum LIKE '%110';
8.单独引用联合索引里非第一位置的索引列
CREATE TABLE t1 (id INT,NAME VARCHAR(),age INT ,sex ENUM('m','f'),money INT);
ALTER TABLE t1 ADD INDEX t1_idx(money,age,sex);
DESC t1
SHOW INDEX FROM t1
#走索引的情况测试
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE money= AND age= AND sex='m';
#部分走索引
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE money= AND age=;
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE money= AND sex='m';
#不走索引
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE age=
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE age= AND sex='m';
EXPLAIN SELECT NAME,age,sex,money FROM t1 WHERE sex='m';
MySQL学习【第八篇索引优化】的更多相关文章
- 数据库MySQL学习笔记高级篇
数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...
- MySql数据表设计,索引优化,SQL优化,其他数据库
MySql数据表设计,索引优化,SQL优化,其他数据库 1.数据表设计 1.1数据类型 1.2避免空值 1.3text类型优化 2.索引优化 2.1索引分类 2.2索引优化 3.SQL优化 3.1分批 ...
- MySQL学习(二)索引原理及其背后的数据结构
首先区分几个概念: 聚集索引 主索引和辅助索引(即二级索引) innodb中每个表都有一个聚簇索引(clustered index ),除此之外的表上的每个非聚簇索引都是二级索引,又叫辅助索引(sec ...
- MySQL学习笔记十五:优化(2)
一.数据库性能评测关键指标 1.IOPS:每秒处理的IO请求次数,这跟磁盘硬件相关,DBA不能左右,但推荐使用SSD. 2.QPS:每秒查询次数,可以使用show status或mysqladmin ...
- MySQL学习笔记十四:优化(1)
SQL优化 1.查看各种SQL执行的频率 mysql> show status like 'Com_select';--Com_insert,Com_delete,connections(试图连 ...
- MySQL学习(二)索引与锁 --- 2019年1月
1.Order By 是怎么工作的 MySQL做排序是一个成本比较高的操作.MySQL会为每个线程分配一个 sort_buffer 内存用于排序,该内存大小为 sort_buffer_size. 全字 ...
- MySQL数据库高级二:索引优化
索引优化非常的重要 1.预热 java开发 DBA培训很少,需要经验磨练 索引优化的效果非常好 左外连接 MySQL没有全连接 7种join一定要会写 具体见武林的例子 union的字段顺序要相同 6 ...
- MySQL学习(七) 索引选择(半原创)
概述 该篇文章主要阐述一个例子(例子来自参考资料,侵删),然后总结今天相关的知识点. 例子 (例子来自参考文章,非原创) 创建表并插入数据,并执行查询 CREATE TABLE `t` ( `id` ...
- Mysql学习笔记(九)索引查询优化
PS:上网再次看了一下数据库关于索引的一些细节...感觉自己学的东西有点少...又再次的啃了啃索引.... 学习内容: 索引查询优化... 上一章说道的索引还不是特别的详细,再补充一些具体的细节... ...
随机推荐
- Forword与sendRedirect的区别
二.本质区别 解释一 一句话,转发是服务器行为,重定向是客户端行为.为什么这样说呢,这就要看两个动作的工作流程: 转发过程:客户浏览器发送http请求——>web服务器接受此请求——>调用 ...
- Non-resolvable parent POM for com.*******
场景: 同事新打了一个jar包到私服里面,自己删除了本地对应的中央仓库的依赖包,再次重新下载. 于是我又打开了一个idea的窗口重新引入这个项目,然后重新下载依赖的服务. 结果就一直报这个问题... ...
- win10_64位系统下安装ALM12.01(QC),笔者只在Win10平台上试过,大家也可以在win7的平台上试一下,一个道理!(Alpha)
HP的ALM是一个非常全面的缺陷管理系统,但安装学习的非常的麻烦,以前学的是ALM,好久没用带今天想学习一下发现安装的非常的困难 !发现网上对ALM的系统安装的介绍非常少,也非常琐碎!今天就借着自己学 ...
- Selenium2+python自动化
一.打开网站1.第一步:从selenium里面导入webdriver模块2.打开Firefox浏览器(Ie和Chrome对应下面的)3.打开百度网址二.设置休眠1.由于打开百度网址后,页面加载需要几秒 ...
- sql根据子查询更新语句
update … from语句 测试环境准备 create table #table1 ( id ) ); go create table #table2 ( id ) ); go , , , , , ...
- 【Win10+eclipse+MinGW+QT安装教程】已有eclipse环境下配置QT插件出错详解
(纪念一下装了一整天濒临绝望的自己[/doge]) (以下所有下载项一律使用32位) step1:下载安装eclipse.适配的jdk.MinGW和QT 1.下载32位eclipse for c++以 ...
- PHP: APC Configuration and Usage Tips and Tricks
原文链接:http://www.if-not-true-then-false.com/2012/php-apc-configuration-and-usage-tips-and-tricks/3/ T ...
- css属性之flex属性
flex属性 规定了弹性元素如何伸长或缩短以适应flex容器中的可用空间.是一个简写属性,可以同时设置flex-grow, flex-shrink, flex-basis三个子属性. /* Basic ...
- python网络爬虫--简单爬取糗事百科
刚开始学习python爬虫,写了一个简单python程序爬取糗事百科. 具体步骤是这样的:首先查看糗事百科的url:http://www.qiushibaike.com/8hr/page/2/?s=4 ...
- jq判断鼠标滚轴向上滚动还是向下滚动
$(document).on("mousewheel DOMMouseScroll", function (e) { var delta = (e.originalEvent.wh ...