SQL语句优化方式

Wesley13
• 阅读 560
  • 不要使用*号进行查询操作,使用具体字段.

  • 索引

    • 在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) 代替

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Kevin501 Kevin501
3年前
常见SQL编写和优化
常见的SQL优化方式1.对查询进行优化,应尽量避免全表扫描,首先应考虑在where及orderby涉及的列上建立索引。2.应尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:selectidfromtwherenumisnul
Wesley13 Wesley13
2年前
mysql千万级大数据SQL查询优化
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在where及orderby涉及的列上建立索引。2.应尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:selectidfromtwherenumisnull可以在num上设置默认值0,确保表中num列没有
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL 常用30种SQL查询语句优化方法
1、应尽量避免在where子句中使用!或<操作符,否则将引擎放弃使用索引而进行全表扫描。2、对查询进行优化,应尽量避免全表扫描,首先应考虑在where及orderby涉及的列上建立索引。3、应尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描。如:selectidfromt
Wesley13 Wesley13
2年前
Sql优化技巧
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在where及orderby涉及的列上建立索引。2.应尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:selectidfromtwherenumisnull可以在num上设
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这