1、创建索引

(1) 要尽量避免全表扫描,首先应考虑在where 及order by涉及的列上建立索引

(2) 在经常需要进行检索的字段上创建索引,一个表中的索引最好不要超过6个

2、避免在索引上使用计算

3、使用预编译查询

(1) 程序中通常是根据用户的输入来动态执行SQL ,这时应该尽量使用参数化SQL,这样不仅可以避免SQL 注入漏洞攻击,最重要数据库会对这些参数化SQL进行预编译,这样第一次执行的时候DBMS会为这个SQL语句进行查询优化并且执行与便于,这样以后再执行这个SQL的时候就直接使用预编译的结果,这样可以大大提高执行的速度

4、调整where字句中的连接顺序

(1) DBMS一般采用自上而下的顺序解析where字句,根据这个原理表连接最好写在其他where条件之前,那些可以过滤掉最大数据记录

5、尽量将多条SQL语句压缩到一句sql中

(1) 每次执行SQL的时候都要建立网络连接,进行权限校检、进行SQL 语句的查询优化发送执行结果,这个过程是非常耗时的,因此尽量避免过多的执行SQL语句,能够压缩到一句SQL执行的语句就不要用多条来执行

6、用where字句替换having字句

(1) Having只会只会在检索出所有记录之后才对结果集进行过滤,而where则是在聚合前刷选记录,having中的条件一般用于聚合函数的过滤,初次之外,应将条件写在where字句中

7、使用表的别名

(1) 涉及多张表时,使用表别名可以减少解析的时间并减少哪些列名歧义引起的语法错误

8、使用UNION ALL替换UNION

9、使用临时表暂存中间结果

(1) 临时表避免了多次扫描主表,减少了程序中“共享锁”阻塞“更新锁”,减少了阻塞,提高了并发性能,但是也得避免频繁创建和删除临时表,以减少系统表资源的消耗

10、只在必要的情况下使用事务begin translation

11、尽量避免使用游标

(1) 尽量避免向客户返回大数据量,若数据量过大,应该考虑相应的需求是否合理,因为游标的效率较差,如果游标操作的数据超过一万行,那么应该考虑改写

12、用varchar/nvarchar代替char/nchar

(1) 变长字段存储空间小,变长字段的null是不占用空间的

13、查询语句优化

(1) 任何地方不要使用* ,要用具体的字段名替换*

(2) 尽量避免在where子句中进行null值判断,否则导致引擎放弃使用索引而进行全表扫描

(3) 不能前置%

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

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

(6) 考虑在where及order by涉及涉及的列上建立索引

(7) 避免在where字句中使用!=或<>操作符

(8) 避免在where字段字段进行表达书和函数操作

14、更新update语句优化

(1) 如果只更改1、2个字段,不要update全部字段,频繁调用会引起明显的性能消耗,同时带来大量的日志

15、删除delete语句优化

(1) 最高效的删除重复记录的方法

DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP_NO = E.EMP_NO);

16、插入insert语句优化

(1) 如果一次插入数据量很大,可以使用select into代替create table,避免造成大量log,如果数据量不大,应先create table 然后insert

17、避免频繁创建和删除临时表,以减少系统表资源的消耗

18、避免向客户返回大量的数据量

19、尽量避免大事务操作

数据库SQL调优的几种方式的更多相关文章

  1. php开发面试题---数据库SQL调优的几种方式

    php开发面试题---数据库SQL调优的几种方式 一.总结 一句话总结: 创建索引:尽量避免使用or或者like,或者sql中的正则 存储查询中间结果 可以加sphinx搜索技术 查询优化 主从数据库 ...

  2. 数据库SQL调优的几种方式(转)

    原文地址:https://blog.csdn.net/u010520146/article/details/81161762 在项目中,SQL的调优对项目的性能来讲至关重要,所有掌握常见的SQL调优方 ...

  3. 数据库SQL调优的几种方式 EFcore读的情况下使用 AsNoTracking非跟踪查询

    不要用GUID 当主键 没有规律 可以用雪花ID DBA 优化法则 硬件资源是根本,DBA是为了充分利用硬件资源 一般清空下可以不使用外键 可以提高性能 合理使用临时表 临时表分页; 一些查询语句加w ...

  4. 数据库SQL调优之"执行计划"【未完待续】

    什么是“执行计划”?“执行计划”怎么用于SQL调优? 内容待添加... 参考文章: [1]写SQL要学会使用"执行计划" by 鹏霄万里展雄飞      

  5. <随便写>数据库调优的几种方式

    1.创建索引 要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引 在经常需要进行检索的字段上创建索引,比如要按照表字段username进行检索,那么就应该在姓名字段 ...

  6. OCM_第十五天课程:Section6 —》数据库性能调优 _SQL 访问建议 /SQL 性能分析器/配置基线模板/SQL 执行计划管理/实例限制

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  7. OCM_第十四天课程:Section6 —》数据库性能调优_各类索引 /调优工具使用/SQL 优化建议

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  8. SQL调优常用方法

    在使用DBMS时经常对系统的性能有非常高的要求:不能占用过多的系统内存和 CPU资源.要尽可能快的完成的数据库操作.要有尽可能高的系统吞吐量.如果系统开发出来不能满足要求的所有性能指标,则必须对系统进 ...

  9. SQL调优

    # 问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用 系统提交实际应用后,随着数据库中数据的增加,系 ...

随机推荐

  1. servlet的生命周期和工作原理介绍

    一.servlet生命周期 Servlet生命周期分为三个阶段: 1)初始化阶段: 调用init()方法 2)响应客户请求阶段:调用service()方法 3)终止阶段:调用destroy()方法 T ...

  2. linux命令查询网站

    http://linux.51yip.com/ http://man.linuxde.net/ Linux命令查询手册Linux终端下 esc + . 可以获取上次文件名

  3. 在Linux命令行中使用计算器的5个命令

    大家好,我是良许. 在使用 Linux 时,我们有时会需要做一些计算,那么我们就可能需要用到计算器.在 Linux 命令行里,有许多计算器工具,这些命令行计算器可以让我们执行科学计算.财务计算或者一些 ...

  4. 第4篇 Scrum 冲刺博客

    1.站立会议 照骗 进度 成员 昨日完成任务 今日计划任务 遇到的困难 钟智锋 重新设计项目执行流程 实现技能 庄诗楷 游戏窗口的制作 制作了开始游戏的界面,感觉还不错 无 易德康 完成所有棋子的移动 ...

  5. 第一篇 Scrum冲刺博客

    一.Alpha任务认领 冯荣新 任务 预计时间 搜索框 0.5h 首页轮播图 0.5h 分类导航 2h 商品列表 2h 商品详情轮播图 0.5h 商品底部工具栏 1h 购物车列表 1.5h 购物车工具 ...

  6. Jenkins读取Allure结果出报告

    1.想 jenkins 有展示和解析 Allure 报告的能力,就必须装 Allure 插件. 「安装插件地址:」 http://updates.jenkins-ci.org/download/plu ...

  7. SAP ABAP RFC接口通用日志工具:abap fm logger

    很早之前就想写个能记录函数模块日志的通用工具,最早尝试时,没有想清楚插入代码的体积问题.在一些群友的提醒下,了解到可以用宏来处理这一问题.不过当时比较忙,就没有动笔.最近又想起这件事,花了2天完成了一 ...

  8. GPU虚拟机创建时间深度优化

    ​桔妹导读:GPU虚拟机实例创建速度慢是公有云面临的普遍问题,由于通常情况下创建虚拟机属于低频操作而未引起业界的重视,实际生产中还是存在对GPU实例创建时间有苛刻要求的业务场景.本文将介绍滴滴云在解决 ...

  9. 使用Apache的反向代理会影响搜索引擎的收录和排名吗

    http://www.wocaoseo.com/thread-292-1-1.html 百度官方观点:Baiduspider对站点的抓取方式和普通用户访问一样,只要普通用户能访问到的内容,我们就能抓取 ...

  10. 文件操作 -- 生成java文件

    import hashlibimport os def genJavaFile(packageName, soFile):    className, suffix = soFile.split('. ...