zoukankan      html  css  js  c++  java
  • MySQL查看两个查询的差集

    目前我知道有两个办法,一个是not in, 另外一个是left join

    大部分情况下,left join的效率比较高

    1. 使用 not in 函数

    EXPLAIN SELECT
    	count(*) 
    FROM
    	( SELECT id FROM arg_approve WHERE create_time > '2020-08-13 00:00:00' ) a 
    WHERE
    	a.id NOT IN (
    	SELECT
    		approve_id 
    	FROM
    	arg_approve_query)
    

    查看执行计划:

    2. 使用left join

    EXPLAIN SELECT
    	a.session_hash,
    	a.create_time,
    	b.approve_id 
    FROM
    	( SELECT id, session_hash, create_time FROM arg_approve WHERE create_time > '2020-08-14 00:00:00' ) a
    	LEFT JOIN arg_approve_query b ON a.id = b.approve_id 
    WHERE
    	approve_id IS NULL
    

    查看执行计划:

    3. 分析

    首先可以看这篇文章构建一下基础
    https://www.cnblogs.com/kongzhongqijing/articles/3544020.html

    分析我们的执行计划,主要看索引类型和rows,使用left join的索引是ref,而not in使用的index。rows列很明显,外层扫描的rows行数,left join明显优于not in。

    索引类型的效率关系:system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL

    所以使用left join会比not in更加有效率。

  • 相关阅读:
    习题2-4 求交错序列前N项和 (15分)
    015_Web WPI
    014_捆绑包与显示模式
    013_模型验证
    012_模型绑定
    011_URL和Ajax辅助器方法
    010_模板辅助器方法
    009_辅助器方法
    008_视图
    007_控制器可扩展性
  • 原文地址:https://www.cnblogs.com/StivenYang/p/13930705.html
Copyright © 2011-2022 走看看