首页 > 数据库技术 > 详细

MySQL查看两个查询的差集

时间:2020-11-05 15:15:53      阅读:130      评论:0      收藏:0      [点我收藏+]

目前我知道有两个办法,一个是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)

查看执行计划:
技术分享图片

  1. 使用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

查看执行计划:
技术分享图片

MySQL查看两个查询的差集

原文:https://www.cnblogs.com/StivenYang/p/13930705.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!