zoukankan      html  css  js  c++  java
  • Sargable

    https://en.wikipedia.org/wiki/Sargable

    In relational databases, a condition (or predicate) in a query is said to be sargable if the DBMS engine can take advantage of an index to speed up the execution of the query. The term is derived from a contraction of Search ARGument ABLE

    A query failing to be sargable is known as a non-sargable query and typically has a negative effect on query time, so one of the steps in query optimization is to convert them to be sargable. The effect is similar to searching for a specific term in a book that has no index, beginning at page one each time, instead of jumping to a list of specific pages identified in an index.

    The typical situation that will make a SQL query non-sargable is to include in the WHERE clause a function operating on a column value. The WHERE clause is not the only clause where sargability can matter; it can also have an effect on ORDER BY, GROUP BY and HAVING clauses. The SELECT clause, on the other hand, can contain non-sargable expressions without adversely affecting the performance.

    • Sargable operators: =, >, <, >=, <=, BETWEEN, LIKE, IS [NOT] NULL
    • Sargable operators that rarely improve performance: <>, IN, OR, NOT IN, NOT LIKE

    Simple example

    WHERE clauses that are sargable typically have field values on the left of the operator, and scalar values or expressions on the right side of the operator.

    Not sargable:

    SELECT *
    FROM   myTable
    WHERE  11.7 < SQRT(myIntField)

    This is not sargable because myIntField is embedded in a function. If any indexes were available on myIntField, they could not be used. In addition, SQRT() would be called on every record in myTable.

    Sargable version:

    SELECT *
    FROM   myTable
    WHERE  myIntField > 11.7 * 11.7

    This is sargable because myIntField is NOT contained in a function, making any available indexes on myIntField potentially usable. Furthermore, the expression is evaluated only once, rather than for each record in the table. 

  • 相关阅读:
    设计模式——迭代器模式
    FTP服务:FileZilla的配置和使用
    FTP服务:使用FileZilla搭建FTP服务
    FTP服务:ISS搭建服务
    javaweb项目使用RSA算法
    我在博客园的第一篇博客
    杰表打印跟乱码修改
    jsp页面角色判断
    test : 摘自 https://www.cnblogs.com/yyman001/p/3366764.html
    mybatis中sql查询不到数据单独运行sql可以获取数据
  • 原文地址:https://www.cnblogs.com/chucklu/p/14821797.html
Copyright © 2011-2022 走看看