首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【MySQL系列】- MySQL执行计划一览

某个表经过搜索条件过滤后剩余记录条数的百分比 Extra None 额外的信息 字段解释 对select_type 字段解释之前先了解一下下面几个名词: ❝「子查询物化」:子查询的结果通常缓存在内存或临时表中...IN子查询的查询语句中,如果查询优化器决定将IN子查询转换为EXISTS 子查询,而且子查询可以使用到主键进行等值匹配的话,那么该子查询执行计划 的 type 列的值就是 unique_subquery...如果查询中使用到了内部的临时表,在执行计划的Extra列将会显示Using temporary Using where:当我们使用全表扫描来执行对某个表的查询,并且该语句的WHERE子句中有针对该表的搜索条件时...,在 Extra 列中会显示Using where;当使用索引访问来执行对某个表的查询,并且该语句的 WHERE 子句中有除了该索引包含的列之外的其他搜索条件时,在 Extra 列中也会显示Using...Using where只是表示 MySQL使用where子句中的条件对记录进行了过滤。

76420

Oracle查询性能优化

原则一:注意WHERE子句中的连接顺序: ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE...因此你可以插入1000 条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....SELECT…FROM DEPARTMENT WHERE DEPT_CODE = ‘123456'(有效) 5、避免改变索引列的类型.: 当比较不同数据类型的数据时, ORACLE自动对列进行简单的类型转换...优化GROUP BY: 提高GROUP BY 语句的效率, 可以通过将不需要的记录在GROUP BY 之前过滤掉.下面两个查询返回相同结果但第二个明显就快了许多....因为子查询的开销是相当昂贵的。具体的例子在后面的案例“一条SQL的优化过程”中。

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL 性能优化 总结

    ORACLE为管理上述3种资源中的内部花费 (11)用Where子句替换HAVING 子句: 避免使用 HAVING 子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤....(非oracle中)on、where、having这三个都可以加条件的子句中,on 是最先执行,where 次之,having 最后,因为on 是先把不符合条件的记录过滤后才进行统 计,它就可以减少中间运算要处理的数据...系统首先根据各个表之间的联接条 件,把多个表合成一个临时表后,再由where进行过滤,然后再计算,计算完后再由 having 进行过滤。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里。 (12)减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询....因此你可以插入 1000条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引 列中,所以WHERE子句中对索引列进行空值比较将使 ORACLE 停用该索引.

    1.9K20

    MySQL 查询专题

    ❑ IN的最大优点是可以包含其他SELECT语句,使得能够更动态地建立WHERE子句。 ❑ IN WHERE子句中用来指定要匹配值的清单的关键字,功能与OR相当。...NOT操作符 WHERE 子句中的 NOT 操作符有且只有一个功能,那就是否定它之后所跟的任何条件。 GROUP BY 创建分组 GROUP BY 语句根据一个或多个列对结果集进行分组。...HAVING 和 WHERE 的差别 这里有另一种理解方法,WHERE 在数据分组前进行过滤,HAVING 在数据分组后进行过滤。这是一个重要的区别,WHERE 排除的行不包括在分组中。...在指定一条 ORDER BY 子句时,应该保证它是SELECT语句中最后一条子句,否则这将报错 不限制是否使用非选择列进行排序 除了能用列名指出排序顺序外,ORDER BY 还支持按相对列位置进行排序,...where item_price >= 10 ) 列必须匹配 在 WHERE 子句中使用子查询(如这里所示),应该保证SELECT语句具有与 WHERE 子句中相同数目的列。

    5K30

    Java SQL语句优化经验

    ORACLE为管理上述3种资源中的内部花费 (11) 用Where子句替换HAVING子句: 避免使用HAVING子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤....(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再由where进行过滤,然后再计算,计算完后再由having进行过滤。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 (12) 减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: SELECT...因此你可以插入1000 条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.

    2.6K100

    SQL优化法则小记

    , having只会在检索出所有记录之后才对结果集进行过滤....(非 oracle 中)on、where、having 这三个都可以加条件的子句中, on 是最先执行,where 次之,having 最后,因为 on 是先把不符合条件的记录过滤后 才进行统计,它就可以减少中间运算要处理的数据...在多表联接查询时,on 比 where 更早 起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再由 where 进行过滤,然后再计算,计算完后再由 having 进行过滤。...由此可见,要想过 滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定,放在那里. 12.减少对表的查询: 在含有子查询的 SQL 语句中,要特别注意减少对表的查询.例子:...因此你可以插 入 1000 条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以 where子句中对索引列进行空值比较将使 oracle停用该索引.

    2.1K90

    Oracle SQL性能优化

    ORACLE为管理上述3种资源中的内部花费 (11) 用Where子句替换HAVING子句: 避免使用HAVING子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤....(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不 符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表 后,再由where进行过滤,然后再计算,计算完后再由having进行过滤。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候 起作用,然后再决定放在那里 (12) 减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子:     ...因此你可以插入1000 条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.

    2.8K70

    Oracle 数据库拾遗(四)

    Oracle 数据库拾遗(四) 發佈於 2021-01-21 前面介绍的 SELECT 查询语句都是只有一个 SELECT-FROM-WHERE 形式的语句块,本篇再来看看子查询。...对于含有子查询的 SQL 语句来说,SQL 对其执行以下 3 个步骤: 执行子查询,获取指定字段的返回结果 将子查询的结果代入外部查询中 根据外部查询的条件,输出 SELECT 子句中指定的列值记录...事实上,此处返回的结果仍然只有单行。 FROM 子句后的子查询 前面的实例中,子查询都是出现在 WHERE 子句后,作为条件来过滤不需要的记录行。事实上,子查询也可以出现在 FROM 子句中。...SAGE > 20; 需要注意: 在 FROM 子句中以子查询代替表作为查询对象时,如果其后还包含 WHERE 子句,那么 WHERE 子句中的组成条件一定要是子查询能够返回的列值,否则语句执行将出现错误...HAVING 子句后的子查询 前面实例提到 HAVING 子句也能实现条件过滤,其功能与 WHERE 子句类似,因此,HAVING 子句后也可以使用子查询实现条件过滤。

    1.1K30

    如何写优雅的SQL原生语句?

    现在开始我们的学习 语句中各子句完整执行顺序概括(按照顺序号执行) from (注:这里也包括from中的子语句) join on where group by(开始使用select中的别名,后面的语句中都可以使用...4. where 对虚拟表T2进行WHERE条件过滤。...所以子查询非常有必要,它能够对原始的数据首先进行排序,分数最高的那条就是第一条对应的第一条记录。...看一下代码和执行结果与带有子查询的进行比较,不带子查询的查询结果的确查到的最大分数与子查询的最大分数相同,但是根据id确认二者并不是同一条记录。...子句中对字段进行运算或函数(索引相关) 如where amount / 2 > 100,即使amount字段有索引,也无法使用,改成where amount > 100 * 2就可使用amount列上的索引

    1.9K20

    oracle数据库sql语句优化(循环语句有几种语句)

    X WHERE X.TEMP_NO = E.TEMP_NO); 10、减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询。...ORACLE为管理上述3种资源中的内部花销。 16、用Where子句替换HAVING子句: 避免使用HAVING子句,HAVING只会在检索出所有记录之后才对结果集进行过滤。...a、on是先把不符合条件的记录过滤后才进行统计,可以减少中间运算要处理的数据,速度是 最快的; b、where比having快点,因为它过滤数据后才进行sum,在两个表联接时才用on的,所以在一 个表的时候...在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的关联 条件,把多个表合成一个临时表后,再由where进行过滤,然后再计算,计算完后再由having 进行过滤。...因此你可以插入10000条具有相同键值 的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空 值比较将使ORACLE停用该索引。

    2.9K10

    没内鬼,来点干货!SQL优化和诊断

    如果在语句中没有子查询或关联查询,只有唯一的select,每行都将显示1.否则,内层的select语句一般会顺序编号,对应于其在原始语句中的位置 select_type 显示本行是简单或复杂select...最好 key列 实际在查询中是否使用到索引的标志字段 Extra列 Extra 列主要用于显示额外的信息,常见信息及其含义如下: Using where :MySQL 服务器会在存储引擎检索行后再进行过滤...Using filesort:通常出现在 GROUP BY 或 ORDER BY 语句中,且排序或分组没有基于索引,此时需要使用文件在内存中进行排序,因为使用索引排序的性能好于使用文件排序,所以出现这种情况可以考虑通过添加索引进行优化...Where条件下的一条数据,注意使用Limit 说明:在很多情况下我们已知数据仅存在一条,此时我们应该告知数据库只用查一条,否则将会转化为全表扫描 ```mysql 反例(耗时2424.612s)...3400万,taskid是一个普通索引列,可见%%这种匹配方式完全无法使用索引,从而进行全表扫描导致效率极低,而正例通过索引查找数据只需要扫描99条数据即可 避免SQL中对where字段进行函数转换或表达式计算

    69140

    sql必知必会2

    : 子句中可以包含任意数目的列 子句中列出的每列都必须是检索列或者有效的表达式,不能是聚集函数 子句中不可带有长度可变的数据类型 如果分组列中含有NULL行,不管是一行还是多行,都当做一行进行返回 group...by子句必须在where语句之后,在order by子句之前 过滤分组having where指定的过滤行而不是分组;having支持所有的where操作符。...(*) >= 2; -- 再过滤分组 笔记:where在分组前进行过滤;having在数据分组后进行过滤 select vend_id, count(*) as num_prods from products...,默认是升序 select子句顺序 select from where group by having order by 子查询 利用子查询进行过滤 select cust_id -- 2....联结表 SQL最强大的功能之一就是在查询的过程中使用联结表。联结是一种机制,用来在一条select语句中关联表。

    1K10

    Mysql慢sql优化

    表示在 select 或 where 列表中包含了子查询,MATERIALIZED:表示 where 后面 in 条件的子查询 UNION:表示 union 中的第二个或后面的 select 语句 UNION...Using where:表示 SQL 操作使用了 where 过滤条件。...应尽量避免在 WHERE 子句中对字段进行 NULL 值判断 应尽量避免在 WHERE 子句中使用!...如果在 WHERE 子句中使用参数,也会导致全表扫描 应尽量避免在 WHERE 子句中对字段进行表达式操作 应尽量避免在where子句中对字段进行函数操作 任何对列的操作都将导致表扫描,它包括数据库函数...* FROM record WHERE DATE= '1999/12/01' (< 1秒) GROUP BY 提高GROUP BY语句的效率, 可以通过将不需要的记录在GROUP BY 之前过滤掉.下面两个查询返回相同结果

    11210

    没内鬼,来点干货!SQL优化和诊断

    如果在语句中没有子查询或关联查询,只有唯一的select,每行都将显示1.否则,内层的select语句一般会顺序编号,对应于其在原始语句中的位置 select_type 显示本行是简单或复杂select...「DEPENDENT UNION」:UNION 操作的第二个或者之后的查询,取决于外部查询 「UNION RESULT」:UNION 产生的结果集 「DERIVED」:出现在 FROM 字句中的子查询...,常见信息及其含义如下: 「Using where」 :MySQL 服务器会在存储引擎检索行后再进行过滤 「Using filesort」:通常出现在 GROUP BY 或 ORDER BY 语句中,且排序或分组没有基于索引...Where条件下的一条数据,注意使用Limit 说明:在很多情况下我们已知数据仅存在一条,此时我们应该告知数据库只用查一条,否则将会转化为全表扫描 # 反例(耗时2424.612s) select *...3400万,taskid是一个普通索引列,可见%%这种匹配方式完全无法使用索引,从而进行全表扫描导致效率极低,而正例通过索引查找数据只需要扫描99条数据即可 避免SQL中对where字段进行函数转换或表达式计算

    64020

    MySQL查询优化-基于EXPLAIN

    从表中仅使用索引树中的信息就能获取查询语句的列的信息, 而不必进行其他额外查找(seek)去读取实际的行记录。当查询的列是单个索引的部分的列时, 可以使用此策略。...Pushdown),即如果你的查询条件里有部分可以走索引,那么则会先将条件推到底层的存储引擎层去做一部分过滤,找到所有符合索引条件的数据行,随后用 WHERE 子句中的其他条件去过滤这些数据行,以此减少查询的条数...ICP 是在取出索引的同时,判断是否可以根据索引当中的列进行 where 条件过滤,将 where 条件的过滤放在了存储引擎。 ICP 的执行步骤是: 在存储引擎获取一条索引基础数据。...存储引擎根据上面的数据,结合where条件,判断是否满足where条件,如果没有满足条件,回到第一步,筛选下一条数据,否则的话,进行下面的判断。...temporary 创建一个临时表来存储数据,一般出现在对非索引的列集进行 group by 时 (需要添加合适的索引) using where 通常是对全表/全索引进行扫描之后,再用 where

    1.6K20

    SQL 性能调优

    ORACLE为管理上述3种资源中的内部花费 回到顶部 (11) 用Where子句替换HAVING子句 避免使用HAVING子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤....(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不 符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表 后,再由where进行过滤,然后再计算,计算完后再由having进行过滤。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 回到顶部 (12) 减少对表的查询 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子:    ...因此你可以插入1000 条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.

    3.2K10

    SQL语句规范参考

    SQL语句包含多表连接时,必须加上表的别名,对每个字段的使用都要带上表别名。...例如在where子句中numeric型和int型的列的比较。 8. 在子查询中前后必须加上括号。...执行SQL时一次应只执行一条,如果多条语句则应分开执行,但必须保持在一个事务中。不得一次执行通过分号等分开的多条语句,这样处理不清晰。 10. 如果能采用or代替,则不宜使用in 语句。...一条SQL语句中不宜使用3层以上的嵌套查询。如果超过,则应在Java等应用服务器程序中处理。 5. 一条SQL语句中不得从4个及以上表中同时取数。...因为这些对列的操作会将导致表扫描,影响性能。 9. 在where子句中,如果有多个过滤条件,应将索引列或过滤记录数最多的条件放在前面。 10. 能用连接方式实现的功能,不得用子查询。

    1.2K20

    【MySQL】执行计划 explain 及 一条select语句在MySQL中的奇幻之旅

    server层过滤后,剩下满足查询的记录数量的比例) extra Additional information (额外的信息说明) 重要字段(我个人认为的)再释义: id:这列就是查询的编号,如果查询语句中没有子查询或者联合查询这个标识就一直是...:用于where中的in查询,完全替换子查询,效率更高。...语句为value IN (SELECT primary_key FROM single_table WHERE some_expr) index_subquery:子查询中的返回结果字段组合是一个索引(...Using index:使用了覆盖索引,查询列都为索引字段 Using where:使用了where语句 Using temporary :查询结果进行排序的时候使用了一张临时表 Using filesort...:对数据使用一个外部的索引排序 Using index condition:使用了索引下推 一条select语句在MySQL中的奇幻之旅 注:MySQL8.0起以取消图中第九步(查询缓存)原因:把查询语句作为

    1.2K20

    数据库性能优化之SQL语句优化

    ORACLE为管理上述3种资源中的内部花费 (11) 用Where子句替换HAVING子句: 避免使用HAVING子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤....(非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表 后,再由where进行过滤,然后再计算,计算完后再由having进行过滤。...(12) 减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: SELECT TAB_NAME FROM TABLES WHERE (TAB_NAME,DB_VER) = (...分析 select emp_name form employee where salary > 3000 在此语句中若salary是Float类型的,则优化器对其进行优化为Convert

    5.7K20
    领券