zoukankan      html  css  js  c++  java
  • Sql优化-必劳记!

    0. 尝试在合适的场景下,用 Charindex()函数代替 like,或者全文索引进行 内容搜寻。%like%不走索引,'like%'后百分号可以走索引。

    1.
    调整不良SQL通常可以从以下几点切入:
    ? 检查不良的SQL,考虑其写法是否还有可优化内容
    ? 检查子查询 考虑SQL子查询是否可以用简单连接的方式进行重新书写
    ? 检查优化索引的使用
    ? 考虑数据库的优化器

    2. 避免出现SELECT * FROM table 语句,要明确查出的字段

    3. 在一个SQL语句中,如果一个where条件过滤的数据库记录越多,定位越准确,则该where条件越应该前移

    4. 查询时尽可能使用索引覆盖。即对SELECT的字段建立复合索引,这样查询时只进行索引扫描,不读取数据块。

    5. 在判断有无符合条件的记录时建议不要用SELECT COUNT (*)和select top 1 语句。

    6. 使用内层限定原则,在拼写SQL语句时,将查询条件分解、分类,并尽量在SQL语句的最里层进行限定,以减少数据的处理量。

    7. 应绝对避免在order by子句中使用表达式

    8. 如果需要从关联表读数据,关联的表一般不要超过7个。

    9. 小心使用 IN 和 OR,需要注意In集合中的数据量。建议集合中的数据不超过200个。

    10. >用>=代替,<用<=代替,这样可以有效的利用索引。

    11. 在查询时尽量减少对多余数据的读取包括多余的列与多余的行

    12. 对于复合索引要注意,例如在建立复合索引时列的顺序是F1,F2,F3,则在where或order by子句中这些字段出现的顺序要与建立索引时的字段顺序一致,且必须包含第一列。

    15. 在WHERE 子句中,避免对列的四则运算,特别是where 条件的左边,严禁使用运算与函数对列进行处理。比如有些地方 substring 可以用like代替

    16. 如果在语句中有not in(in)操作,应考虑用not exists(exists)来重写,最好的办法是使用外连接实现。

    18. 请小心不要对过多的列使用列函数和order by,group by等,谨慎使用disti软件开发

    19. 用union all 代替 union,数据库执行union操作,首先先分别执行union两端的查询,将其放在临时表中,然后在对其进行排序,过滤重复的记录。
    当已知的业务逻辑决定query A和query B中不会有重复记录时,应该用union all代替union,以提高查询效率。

    数据更新的效率
    1. 在一个事物中,对同一个表的多个insert语句应该集中在一起执行
    2. 在一个业务过程中,尽量的使insert,update,delete语句在业务结束前执行,以减少死锁的可能性。
    INNER JOIN     等价于   JOIN
    你可以理解为 JOIN   是 INNER JOIN 的缩写。

    LEFT JOIN 等价于 LEFT OUTER JOIN
    RIGHT JOIN 等价于 RIGHT OUTER JOIN
  • 相关阅读:
    MVC OnActionExecuting,OnResultExecuted 的用法
    MindManager脑图之项目管理甘特图
    jQuery.Autocomplete实现自动完成功能(经典)
    常见26个jquery使用技巧详解(比如禁止右键点击、隐藏文本框文字等)
    用ATL创建COM组件详细解说
    STL中的常用的vector,map,set,Sort用法
    绘图效率完整解决方案——三种手段提高GDI/GDI+绘图效率
    C++面试
    iOS开发UI篇—iOS开发中三种简单的动画设置
    OS开发UI篇—IOS开发中Xcode的一些使用技巧
  • 原文地址:https://www.cnblogs.com/x-poior/p/5168811.html
Copyright © 2011-2022 走看看