四,mysql优化——sql语句优化之索引二
1,在什么列适合添加索引
(1)较频繁的作为查询条件字段应该添加索引
select * from emp where empid = 2;
(2)唯一性太差的字段不适合添加索引,即时频繁作为查询条件。
select * from emp where sex = '男';
(3)更新非常频繁的字段不适合创建索引。
select * from emp where logincount = 2;
(4)不会出现在where条件中的字段,不应该创建索引。
2,索引的种类
(1)主键索引,把某列设为主键,此列就成为主键索引。
(2)唯一索引(unique),该列具有唯一性,还是索引。
(3)普通索引(index),
(4)全文索引(FULLTEXT),是有MyISAM存储引擎支持全文索引。
(5)复合索引,多列组成一个索引。
3,索引的操作
(1)添加索引
create [unique|FULLTEXT] index 索引名 on 表名(列名)
alter table 表名 add index 索引名(列名)
以上两种方式没法创建主键索引,创建主键索引语句:alter table 表名 add primary key(列)
(2)删除索引
drop index 索引名 on 表名
alter table 表名 drop index index_name
以上没法删除主键索引,删除主键索引语句如下:alter table 表名 drop primary key
(3)显示索引
show indexes from 表名
show keys from 表名
4,索引的使用
(1)下列几种情况有可能使用索引
(a)对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用。
news数据表 id title content author ,
设定title和author为索引title_author,那么查询条件中有title字段时候,使用到title_author索引;如果查询条件没有title,只有author,则使用不到title_author索引。
alter table news add index title_author (title,author)。
select * from news where title = '体操奥运会夺冠'; //用到索引
select * from news where author = '李哲'; //使用不到索引
(b)对于使用like的查询,查询如果是'%aaa'不会使用到索引,'aaa%'会使用到索引。
news数据表 id title content author ,
设定title为索引title_index,在查询条件中title字段开头是%,则不能启用title_index索引;字段开头必须不为%,才会启用索引。
alter table news add index title_index(index);
select * from news where title like '%奥运会夺金'; //没法使用索引
select * from news where title like '奥运会%夺金'; //使用索引
select * from news where title like '%奥运会夺金%'; //使用索引
(2)下列几种情况使用不到索引
(a)如果条件中由or,即使其中有条件带索引也不会使用。
(b)对于多列索引,不是使用的第一部分,则不会使用索引。
(c)like查询是以%开头。
(d)如果列类型是字符串,那一定要在条件中将数据使用引号引用起来。否则不使用索引。
(e)如果mysql估计使用全表扫描要比使用索引快,则不使用索引。比如数据表中记录特别少,那可以直接扫描,不用索引。
5,查看索引的使用情况
show status like 'Handle_read%'
其中,Handle_read_key,这个值越高越好,越高表示使用索引查询到的次数越多;
Handle_read_rnd_next,这个值越高,说明查询低效;
四,mysql优化——sql语句优化之索引二的更多相关文章
- mysql的sql语句优化方法面试题总结
mysql的sql语句优化方法面试题总结 不要写一些没有意义的查询,如需要生成一个空表结构: select col1,col2 into #t from t where 1=0 这类代码不会返回任何结 ...
- php面试专题---MySQL常用SQL语句优化
php面试专题---MySQL常用SQL语句优化 一.总结 一句话总结: 原理,万变不离其宗:其实SQL语句优化的过程中,无非就是对mysql的执行计划理解,以及B+树索引的理解,其实只要我们理解执行 ...
- MySQL常用SQL语句优化
推荐阅读这篇博文,索引说的非常详细到位:http://blog.linezing.com/?p=798#nav-3-2 在数据库日常维护中,最常做的事情就是SQL语句优化,因为这个才是影响性能的最主要 ...
- MySQL之SQL语句优化
语句优化 即优化器利用自身的优化器来对我们写的SQL进行优化,然后再将其放入InnoDB引擎中执行. 条件简化 移除不必要的括号 select * from x where ((a = 5)); 上面 ...
- 三,mysql优化--sql语句优化之索引一
1,需求:如何在一个项目中,找到慢查询的select,mysql数据库支持把慢查询语句,记录到日志中.供程序员分析.(默认不启用此功能,需要手动启用) 修改my.cnf文件(有些地方是my.ini) ...
- MySQL 数据库--SQL语句优化
explain查询和分析sql 开发中,为满足一业务功能,使用mysql书写sql时,一条sql往往有多种写法,那么我们就需要选择执行效率比较高的sql. 因此要比较分析sql的执行过程,且同一条sq ...
- Mysql的Sql语句优化
在Mysql中执行Sql语句经常会遇到有的语句执行时间特别长的情况,出现了这种情况我们就需要静下心分析分析. 首先,我们需要确定系统中哪些语句执行时间比较长.这个可以使用Mysql的慢日志来跟踪.下面 ...
- 五,mysql优化——sql语句优化小技巧
1,大批量插入数据 (1)对于MyISAM: alter table table_name disable keys; loading data; alter table table_name ena ...
- 千万级大数据的Mysql数据库SQL语句优化
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
随机推荐
- AOP不起作用的原因之一
在-servlet.xml配置context:component-scan后,Spring在扫描包时,会将所有带 @Service注解的类都扫描到容器中.而-servlet.xml和applicati ...
- windows驱动
DriveEntry() 启动 停止 接口函数 驱动程序名 驱动程序版本号 异常处理 是否运行 声明LPOReceive类型的函数 声明函数指针(外部传进来的回调函数) 存放配置字符串 本机IP 串口 ...
- gdb 调试带参数程序
在gdb中,运行程序使用r或是run命令. 程序的运行,你有可能需要设置下面四方面的事. 1.程序运行参数. set args 可指定运行时参数.(如:set args 10 20 30 40 50) ...
- DB2分页查询SQL
select * from (select row_number() over() as rown,tpag.* from(SELECT int(COALESCE(列名1,0)),COALESCE(列 ...
- 2018.09.28 hdu5434 Peace small elephant(状压dp+矩阵快速幂)
传送门 看到n的范围的时候吓了一跳,然后发现可以矩阵快速幂优化. 我们用类似于状压dp的方法构造(1(1(1<<m)∗(1m)*(1m)∗(1<<m)m)m)大小的矩阵. 然后 ...
- 2018.09.24 bzoj1816: [Cqoi2010]扑克牌(二分答案)
传送门 简单二分答案. 我们二分最终有k个牌堆. 这样joker被选择的张数≤min(k,m)\le min(k,m)≤min(k,m) 并且joker需要被选择的张数应该是∑i−1nmax(0,k− ...
- hdu-1067(最大独立集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1068 题意:一个男生集合和一个女生集合,给出两个集合之间一一对应的关系,求出两个集合中最大独立集的点数 ...
- class和struct
相同点 实际上可以使用这两个关键字定义任何一个类. 区别 1.struct的默认成员访问说明符为public,class的默认成员访问说明符为private(什么叫默认?就是没有写明public.pr ...
- Hdu1427 速算24点 2017-01-18 17:26 46人阅读 评论(0) 收藏
速算24点 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submiss ...
- CGA裁剪算法之线段裁剪算法
CGA裁剪算法之线段裁剪算法 常用的线段裁剪算法有三种:[1]Cohen_SutherLand裁剪算法,[2]中点分割裁剪算法,[3]参数化方法. 1. Cohen_SutherLand裁剪算法 为了 ...