我的编程空间,编程开发者的网络收藏夹
学习永远不晚

常见SQL编写和优化

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

常见SQL编写和优化

常见的SQL优化方式

  1. 对查询进行优化,应尽量避免全表扫描,首先应考虑在where及order by 涉及的列上建立索引

  2. 应尽量避免在 where 子句中对字段进行null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:
select id from t where num is null  

可以在num上设置默认值0,确保表中num列是否存在null值,然后这样查询:

select id from t where num = 0  
  1. 应尽量避免在 where 子句中使用 !=或<> 操作符,否则将引擎放弃使用索引而进行全表扫描。

  2. 应尽量避免在 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   

对于union, 优先使用union all, 避免使用union。

UNION 因为会将各查询子集的记录做比较,故比起UNION ALL ,通常速度都会慢上许多。

一般来说,如果使用UNION ALL能满足要求的话,务必使用UNION ALL。

  1. in 和 not in 慎用,否则会导致全表扫描,如:
select id from t where num in (1,2,3)   

对于连续的数值,能用 between 就不要用 in 了:

select id from t where num between 1 and 3  
  1. 慎用模糊查询,使用 like 两边加“%”--造成索引失效。
    左边没有%,这个索引不会失效。下面的查询将导致全表扫描:
select id from t where name like '%abc%'    
  1. 应尽量避免在 where 子句中对字段进行表达式操作,这将导致引擎放弃使用索引而进行全表扫描。如:
select id from t where num / 2 = 100    

应改为:

select id from t where num = 100 * 2    
  1. 应尽量避免在where子句中对字段进行函数操作,这将导致引擎放弃使用索引而进行全表扫描。
    如:
select id from t where substring(name,1,3)='abc'--name以abc开头的id 

应改为(like 统计第6点):

select id from t where name like 'abc%' 
  1. 不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。

  2. 在使用索引字段作为条件时,如果该索引是复合索引,那么必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,
    否则该索引将不会被使用,并且应尽可能的让字段顺序与索引顺序相一致。

  3. 不要写一些没有意义的查询,如需要生成一个空表结构:
select col1,col2 into #t from t where 1=0   

这类代码不会返回任何结果集,但是会消耗系统资源的,应改成这样:

create table #t(...)    
  1. in和exist。in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。因此,in用到的是外表的索引, exists用到的是内表的索引。

如果查询的两个表大小相当,那么用in和exists差别不大,

如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in

select num from a where num in(select num from b)   

用下面的语句替换:

select num from a where exists(select 1 from b where num=a.num) 
  1. 并不是所有索引对查询都有效,SQL是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL查询可能不会去利用索引,
    如一表中有字段sex,male、female几乎各一半,那么即使在sex上建了索引也对查询效率起不了作用。

  2. 索引并不是越多越好,索引固然可以提高相应的 select 的效率,但同时也降低了 insert 及 update 的效率,
    因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑,视具体情况而定。
    一个表的索引数最好不要超过6个,若太多则应考虑一些不常使用到的列上建的索引是否有必要。

  3. 尽量使用数字型字段,若只含数值信息的字段尽量不要设计为字符型,这会降低查询和连接的性能,并会增加存储开销。
    这是因为引擎在处理查询和连接时会逐个比较字符串中每一个字符,而对于数字型而言只需要比较一次就够了。

  4. 尽可能的使用 varchar 代替 char ,因为首先变长字段存储空间小,可以节省存储空间,
    其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

  5. 任何地方都不要使用 select * from t ,用具体的字段列表代替“*”,不要返回用不到的任何字段。

  6. 避免频繁创建和删除临时表,以减少系统表资源的消耗。
    临时表并不是不可使用,适当地使用它们可以使某些例程更有效,例如,当需要重复引用大型表或常用表中的某个数据集时。但是,对于一次性事件,最好使用导出表。

  7. 在新建临时表时,如果一次性插入数据量很大,那么可以使用 select into 代替 create table,避免造成大量 log ,
    以提高速度;如果数据量不大,为了缓和系统表的资源,应先create table,然后insert

  8. 如果使用到了临时表,在存储过程的最后务必将所有的临时表显式删除,先 truncate table ,然后 drop table ,这样可以避免系统表的较长时间锁定。

  9. 尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该考虑改写。
    使用基于游标的方法或临时表方法之前,应先寻找基于集的解决方案来解决问题,基于集的方法通常更有效。

  10. 与临时表一样,游标并不是不可使用。对小型数据集使用 FAST_FORWARD 游标通常要优于其他逐行处理方法,尤其是在必须引用几个表才能获得所需的数据时。
    在结果集中包括“合计”的例程通常要比使用游标执行的速度快。如果开发时间允许,基于游标的方法和基于集的方法都可以尝试一下,看哪一种方法的效果更好。

  11. 尽量避免大事务操作,提高系统并发能力。

  12. 尽量避免向客户端返回大数据量,若数据量过大,应该考虑相应需求是否合理

参考:https://blog.csdn.net/jie_liang/article/details/77340905
https://blog.csdn.net/weixin_40792878/article/details/81071584

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

常见SQL编写和优化

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

常见SQL编写和优化

常见的SQL优化方式对查询进行优化,应尽量避免全表扫描,首先应考虑在where及order by 涉及的列上建立索引。应尽量避免在 where 子句中对字段进行null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:select id from t w
2020-03-24

常见的SQL优化面试题有哪些

本篇内容介绍了“常见的SQL优化面试题有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!介绍:无论您是创建Web应用程序的开发人员,还是参
2023-03-10

常见的SQL优化面试专题大全

目录介绍:问:比如,现在有个面试官说,现在线上有个SQL执行很慢,你怎么优化?问:慢 SQL 语句的几种常见诱因?问:平时写SQL时该注意什么?有什么经验可谈?问:有哪些影响数据库性能的瓶颈?问:改善SQL性能涉及哪些步骤?问:您如何分析执
2023-03-03

如何实现MySQL底层优化:SQL语句优化的常见技巧和原则

MySQL数据库作为一种常见的关系型数据库,随着数据库中数据量的增加和查询需求的变化,底层优化变得尤为重要。在进行MySQL底层优化的过程中,SQL语句优化是一项至关重要的工作。本文将讨论SQL语句优化的常见技巧和原则,并提供具体的代码示例
如何实现MySQL底层优化:SQL语句优化的常见技巧和原则
2023-11-09

C++ 函数优化详解:优化原则和常见优化手法

优化 c++++ 函数遵循原则:优化关键路径代码、关注热点函数、平衡性能与可读性。常见优化手法包括:内联函数消除函数调用开销;减少间接调用提高直接访问速度;优化循环提高效率;虚拟函数重写防止间接调用;使用对象池避免频繁内存分配。C++ 函数
C++ 函数优化详解:优化原则和常见优化手法
2024-05-01

SQL Update的常见写法有哪些

SQL Update语句是用来更新数据库表中的记录的,常见的写法有以下几种:更新单个字段的值:UPDATE table_nameSET column_name = new_valueWHERE condition;更新多个字段的值:UP
SQL Update的常见写法有哪些
2024-03-08

C++中常见的编译优化问题解决方案

C++中常见的编译优化问题解决方案摘要:在使用C++编写程序时,我们经常会遇到一些性能瓶颈,影响程序的运行效率。为了提高代码的执行效率,我们可以使用编译器进行优化。本文将介绍一些常见的编译优化问题及其解决方案,并给出具体的代码示例。一、循环
2023-10-22

关于SQL Update的四种常见写法

目录SQL Update常见写法SQL中UPDATE 语句Update 语句Person 更新某一行中的一个列更新某一行中的若干列SQL Update常见写法Oralce和DB2都支持的语法:update test1set (test
2022-08-19

tomcat的常见优化有哪些

这篇文章主要为大家展示了“tomcat的常见优化有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“tomcat的常见优化有哪些”这篇文章吧。Tomcat连接器协议优化Tomcat 连接器的三种
2023-06-03

MySQL常见优化方案是什么

MySQL常见优化方案是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。sql优化的几个地方select [字段 优化1]:主要是覆盖索引from []where [条件 优
2023-06-26

常见数据库优化面试题

常见数据库面试题 一.在项目中如何定位慢查询 通过 druid 连接池的内置监控来定位慢 SQL。通过 MySQL 的慢查询日志查看慢 SQL。通过 show processlist,查看当前数据库 SQL 执行情况来定位慢 SQL。 二
2023-08-23

十种H5常见的优化方式

十种 h5 常见优化方式:优化图片大小和格式减少 http 请求使用 cdn启用 gzip 压缩避免使用重定向延迟加载非关键资源优化 javascript使用浏览器缓存监控网站性能使用 amp十种 H5 常见优化方式优化 H5 页面可显著
十种H5常见的优化方式
2024-05-23

Golang函数优化的常见方法

go 函数优化的常见方法包括:避免不必要的分配,可通过池化或重用变量提升性能。选择高效的数据结构,如使用 map 代替 struct 可提高键值对查找效率。避免深度递归,若可行,可通过迭代实现。利用协程并行处理可提升性能。对于高度优化代码,
Golang函数优化的常见方法
2024-04-13

编程热搜

目录