SQL语句优化方式
时间:2019-10-02
本文章向大家介绍SQL语句优化方式,主要包括SQL语句优化方式使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
- 不要使用*号进行查询操作,使用具体字段.
- 索引
- 在where子句和order by 涉及的字段上合理的添加索引.
- where 子句优化
- 避免在where子句中对null值进行判断,应对字段设置默认值
Select id from t where num is null 可以对null值设置默认值为-1(根据自己的实际情况设置) 判断null可以使用 select id from t where num = -1
- 避免在where子句中使用!= 或者<>操作符.
- 尽量避免where子句中使用or 来连接条件
select id from t where num = 1 or num = 5 /*可以优化为*/ select id from t where num = 1 unicon all select id form t where num = 5
- in 和not in 也要慎用
/*连续条件*/ select id from t where num in (1,2,3) /*可以使用 between and */ select id from t where num between 1 and 3 /*更多可以使用exists 代替 in*/ select num from a where num in (select num from t) /*替换语句*/ select num from a where EXISTS (select num from b where a.num = b.num)
- 模糊查询SQL优化
-
/*正常情况下,百分号在后面可以使用索引*/ select nickname from t where nickname like 'DBA%' /*百分号在前面,不能使用索引,解决方案.改写sql,添加reverse索引*/ create index idx_t1_name on t1(reverse(name)) select name from t1 where reverse(name) like reverse('%adc'); /*前后都有百分号,这种情况一般不能使用索引.*/ /*1.搜索条件字符串始终在字符串开始的固定位置出现,可以创建函数索进行优化,先创建subStr 函数索引,再使用like 'abc%'示例:*/ create index idx_substr_t1_name on t1 (substr(name,5,10)); select id, name ,name_type from t1 where substr(name, 5,10) like 'abc%'; /*2.搜索条件始终在字符串结尾的某个固定位置出现,可以创建函数组合索引进行优化,先创建reverse + substr 组合函数索引,再使用like reverse '%abc'*/ create index idx_t1_reverse_name on t1(reverse(substr(name,1,length(name)-4))); select id,name,name_type from t1 where reverse(substr(name,1,length(name)-4)) like reverse('%abc') /*3.搜索字符串再不固定位置出现,优化方案,先建立普通索引列,改写sql*/ create index idx_t1_name on t1(name) select id,name,name_type from t1 where name in (select name from t1 where name like '%abc%')
- 避免在where子句中对字段的 '=' 左边进行函数,算数,或其他表达式运算
- 不要使用select counut(*) from table ,这样不带任何条件的count会引起全表扫描, 可以使用count(1) 代替
原文地址:https://www.cnblogs.com/shar-wang/p/11617855.html
- go语言读取csv文件并输出的方法
- HDUOJ----3342Legal or Not
- go语言基本类型
- HDUOJ----2647Reward
- hduoj------确定比赛名次
- HDUOJ----1165Eddy's research II
- HDUOJ-----1556Color the ball
- HDUOJ-----2175取(m堆)石子游戏
- Golang语言社区-Go语言递归
- go语言mongdb管道使用(一)
- HDUOJ---------2255奔小康赚大钱
- HDUOJ------1711Number Sequence
- HDUOJ---1712 ACboy needs your help
- HDUOJ---1867 A + B for you again
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Python3 列表
- Mycat 核心配置详解
- Python字符串
- 初识 HBase
- Number对象
- Windows 技术篇-设置计划任务,每天自动关机
- Mycat 快速入门
- Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
- 浅谈数据库集群方案
- SkyWalking - 实现微服务监控告警
- Actuator + Prometheus + Grafana搭建微服务监控平台
- Python 用smtplib库发邮件报错:[WinError 10061] 由于目标计算机积极拒绝,无法连接。解决办法
- python运算符
- Windows 技术篇-禁用windows更新服务,解决windows无法关闭更新问题,解决windows自己启用更新问题。
- 搭建 SkyWalking 服务(For ElasticSearch 7)