热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数据库技术:MySql(三)SQL优化策略

SQL优化尽量全职匹配当建立了索引列后,能在where条件中使用索引尽量使用。最佳左前缀法则如果索引了多列,要遵循左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列。E

1、尽量全职匹配

当建立了索引列后,能在where 条件中使用索引尽量使用。

2、最佳左前缀法则

如果索引了多列,要遵循左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列。

 

EXPLAIN SELECT * FROM Student WHERE  age = 25 AND pos = ‘dev’

EXPLAIN SELECT * FROM Student WHERE pos = ‘dev’

EXPLAIN SELECT * FROM Student WHERE NAME = ‘July’

3、不在索引列上做任何操作

不在索引列上做任何操作指的是:计算、函数、(自动or手动)类型转换,会导致索引失效而转向全表扫描。

 

4、范围条件放最后

 

中间有范围查询会导致后面的索引列全部失效

例:index(name, pos, age)

EXPLAIN SELECT * FROM Student WHERE NAME = ‘July’  and age >22 and pos=’manager’

5、覆盖索引尽量用

 

尽量使用覆盖索引:只访问索引的查询(索引列和查询列一致),减少 select  * (*需要解析成字段)。

6、不等于要慎用

6.1 MySql在使用不等于(!=  或者 <> )的时候无法使用索引会导致全表扫描。

例:

select id from t where num is null (num有索引也会全表扫描);

在设计表时可以在 num 上设置默认值0,确保表中没有null值,这样查询 :select id from t where num = 0

 

6.2 如果一定要使用不等于,需要覆盖索引:select 后写字段,不能用*代替

EXPLAIN SELECT name,age,pos FROM Student WHERE NAME != ‘July’;

 

EXPLAIN SELECT name,age,pos FROM Student WHERE NAME <> ‘July’;

 

7、Null/Not有影响

7.1 自定义为not null

 

EXPLAIN select * from Student where name is null

EXPLAIN select * from Student where name is not null

在字段为not null的情况下,使用is null 或 is not null 会导致索引失效。

解决方式:覆盖索引——select * 替换成字段

EXPLAIN select  name,age,pos from Student where name is not null

7.2 自定义为null或者不定义

 

EXPLAIN select * from Student2 where name is null

 

 

EXPLAIN select * from Student2 where name is not null

 

Is not null 的情况会导致索引失效

解决方式:覆盖索引

EXPLAIN select  name,age,pos from Student where name is not null

8、Like查询要当心

Like以通配符开头(’%abc’)mysql索引失效会变成全表扫描的操作

 

解决方式:覆盖索引

EXPLAIN select name,age,pos from Student where name like ‘%july%’

9、字符类型加引号

字符串不加单引号索引失效

10、Or改为Union效率高

10.1 避免在where子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描

例: select  id from t where num=10 or num=20

替换成

select id from t where num=10

union all

select id from t where num=20

 

10.2 第二种解决方式:覆盖索引

EXPLAIN

select name,age from Student where name=’July’ or name = ‘z3’

 

例:

MySql(三)SQL优化策略

 

需要了解更多数据库技术:MySql(三)SQL优化策略,都可以关注数据库技术分享栏目—编程笔记


推荐阅读
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
author-avatar
手机用户2502873943
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有