`
AutomaticThoughts
  • 浏览: 165528 次
社区版块
存档分类
最新评论

SQL 语句优化总结

 
阅读更多

SQL 语句优化总结

个人日常优化SQL语句的总结笔记

目前 DB 承受 日平均 500W PV 左右的站点,数据文件大小在20G左右,表数据量 在 50 - 500 W 左右

仅供参考:

 

1  . 查询的数据行分布情况,决定索引是否用得上,如果查询的数据行在数据表中分布均匀,且所占比重较大,能用上索引;反之,用不上索引

2  . select 的字段数目,特别是 长度较大的字段,对 语句的执行时间影响较大

3  . 语句中有 distinct 时,再在 where 语句中限制日期范围的话,反而会影响性能,无 distinct 时,执行情况是一样的

4  . distinct 一般占到总语句开销的 65 %左右

5  . newid 则视结果集而定,结果集越大,newid 所占语句的总开销比例也就越大

6  . group by 归总时,语句开销和Top 无关,所以,尽量少在大表中group by。

7  . group by 的字段越多,开销越大,且这些字段是用不上索引的,但是 where 中的条件是可以用上索引的。但是不可估量的是,用上索引也不一定能减少开销

8  . 非聚集索引,在 order by 中是用不上的

9  . Row_Number 在IO操作上不是十分的出色,但是在占用CPU资源上,却做的非常好。总体上,还是相当不错的,执行时间较短。

10. 在部分情况下,如果 Or 用好,是和 In 的效率一样的

11. 查询条件过多也会影响性能,且较严重

12. 查询中,UserName='ssssss' 的性能往往会比 UserID=123456 的性能要好

13 . 当语句中出现 in(select id from table1) 时,in里面的表达式一定要加top ,比如 select top 10 * from tables where id in(select top 100 id from table2),特别是在 in 里面取出来的数据比较多,外表又很大的情况

14 . 聚集索引一定要建在在表中分布均匀的字段、增减规律的字段上,比如日期,而尽量避免将聚集索引建立在UserID等字段上

15 . 当 where 中有 like 条件匹配时,where 中的非聚集索引就会失效,引起全表扫描,但是聚集索引是可以用到的

16.  如过允许,请将 可能 引起全表扫表的 SQL 语句,加上 未提交读 的事物隔离级别设置,即 no lock

不断补充中 ......

分享到:
评论

相关推荐

    SQL语句优化总结

    SQL语句优化是一项重要的数据库管理技能,能够显著提高数据库查询性能,减少资源消耗,缩短响应时间。以下是对上述文件内容中提及的关键知识点的详细总结: 1. 选择最有效的表名顺序 在使用基于规则的优化器时,...

    SQL语句优化总结34条

    以下是对标题"SQL语句优化总结34条"中提到的一些重要知识点的详细解释: 1. **选择最有效的表名顺序**:在ORACLE中,FROM子句中的表处理顺序是从右到左,因此基础表(记录条数最少的表或交叉表)应放在最后,以减少...

    ORACLE SQL语句优化总结

    【ORACLE SQL语句优化总结】 在Oracle数据库中,SQL语句的优化是提升系统性能的关键环节。以下是一些常见的优化策略: 1)选择最有效的表名顺序:Oracle的解析器按照FROM子句中表的右到左顺序处理,基础表...

    Oracle Sql语句优化总结.doc

    Oracle SQL语句优化是提高数据库性能的关键,以下是对给定文件内容的详细解释和扩展: 1. **选择最有效率的表名顺序**:在FROM子句中,表的处理顺序是从右到左,基础表(记录条数最少的表)先被处理。在多表连接...

    SQL语句优化手册

    ### SQL语句优化手册 #### 一、引言 随着信息技术的发展,数据库系统在各行业中扮演着越来越重要的角色。为了确保数据库系统能够高效地运行,SQL语句优化成为了提升系统性能的关键因素之一。SQL(Structured Query...

    SQL语句优化方法30例

    在 SQL 语句优化过程中,我们经常会用到 hint,今天我们将总结一下在 SQL 优化过程中常见 Oracle HINT 的用法。 1. /*+ALL_ROWS*/:该 hint 表明对语句块选择基于开销的优化方法,并获得最佳吞吐量,使资源消耗最小...

    通过分析SQL语句的执行计划优化SQL(总结)

    这篇博客"通过分析SQL语句的执行计划优化SQL(总结)"深入探讨了这一主题,下面将对其中的主要知识点进行详细阐述。 1. **执行计划的理解**: 执行计划是数据库管理系统在执行SQL语句之前预先生成的一种详细步骤,它...

    oracle的SQL语句调优总结

    oracle的SQL语句调优总结,Oracle语句优化53个规则详解。

    ORACLE数据库SQL语句编写优化总结.rar

    2. **SQL语句优化技巧**: - **选择适当的WHERE子句**:使用索引来提高查询速度,避免全表扫描。 - **使用绑定变量**:避免SQL注入,提高执行计划的重用率。 - **减少数据访问**:精确选择需要的列,避免SELECT *...

    sql语句的优化

    ### SQL语句优化详解 #### 一、引言 在数据库设计与管理中,SQL语句的优化是一项至关重要的工作。合理的SQL优化不仅能显著提升数据处理速度,还能有效降低服务器资源消耗,从而提高整个系统的响应时间和用户体验。...

    sql语句优化方法总结

    sql语句优化

    索引的SQL语句优化

    ### 知识点详解:“索引的SQL语句优化” #### 重要性 在数据库管理中,SQL(Structured Query Language)语句的优化是确保系统高效运行的关键环节。特别是在大型数据库环境中,一次低效的SQL查询可能会导致整个...

    SQL语句编写优化和基本原理总结

    ### SQL语句编写优化与基本原理深度解析 #### 引言 SQL语句编写优化是数据库性能提升的关键一环,特别是在大数据量...希望本文提供的知识点能够帮助读者在实际工作中更好地应用SQL语句优化策略,提升数据库管理能力。

    一般SQL语句优化整理

    本文将对一些常见的SQL语句优化技巧进行总结整理,帮助开发人员养成良好的SQL编写习惯。 #### SQL语句优化要点 ### 1. EXISTS与NOT EXISTS的使用 - **应用场景**:当需要检查某个记录是否存在时,可以考虑使用`...

    SQL语句优化方法分析与探讨.pdf

    文章《SQL语句优化方法分析与探讨》中,作者详细阐述了SQL语句优化的五大方面:定位、分析、调整、优化和技巧。这些方法都来源于实际应用过程中的探索和总结,目的是为了帮助开发者和数据库管理员更有效地优化SQL...

    Oracle数据库的SQL语句优化.pdf

    总结来说,Oracle数据库的SQL语句优化是一项复杂而系统的工作,需要数据库管理员具备深厚的理论知识和丰富的实践经验。通过对SQL语句的优化,可以确保数据库系统的高效运行,提高应用程序的性能,最终提升整个企业的...

    Oracle——sql语句优化

    ### Oracle SQL语句优化策略详解 #### 操作符优化概览 在Oracle数据库环境中,SQL语句的优化是提升查询效率、减少系统资源消耗的关键环节。通过对特定操作符的合理运用,可以显著改善数据检索的速度与准确性。本文...

    ORACLE数据库SQL语句编写优化总结

    总结以上内容,ORACLE数据库SQL语句的编写优化涉及多方面知识,包括优化器的合理选择、高效的表访问方法、共享SQL语句的使用、索引的正确配置和应用、SQL内部操作的处理以及低效SQL语句的识别与优化等。在实际操作中...

Global site tag (gtag.js) - Google Analytics