博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JOIN与EXISTS(子查询)的效率研究
阅读量:7029 次
发布时间:2019-06-28

本文共 764 字,大约阅读时间需要 2 分钟。

使用MySQL提供的Sample数据库Sakila

现将profiling打开,用来一会查看sql执行时间

set profiling=1;

 exists 子查询与 join联接效率的对比,功能:查看没有演员的电影

EXPLAIN SELECT film_id, language_id FROM sakila.filmWHERE NOT EXISTS(    SELECT * FROM sakila.film_actor    WHERE film_actor.film_id = film.film_id);

 

EXPLAIN SELECT film_id, language_id FROM sakila.film    LEFT JOIN sakila.film_actor USING(film_id)WHERE film_actor.actor_id IS NULL;

他们只有一点细微的区别,一个select_type,还有就是Extra里后者用了Not exists,也就是提前终止算法,当遇到第一个actor_id不是null的时候,就舍弃这个电影的筛选.

最后来看看二者的效率

可知使用子查询Exists的效率要低一些.

 

SELECT DISTINCT film_id FROM sakila.film    JOIN sakila.film_actor USING(film_id);SELECT film_id FROM sakila.film    WHERE EXISTS (    SELECT * FROM sakila.film_actor    WHERE film.film_id = film_actor.film_id);SHOW PROFILES;

可以看出.依然EXISTS效率要低

转载地址:http://ryrxl.baihongyu.com/

你可能感兴趣的文章
OS开发过程中常用开源库
查看>>
关于在多个UItextield切换焦点
查看>>
hdu 2768
查看>>
git记住用户名密码
查看>>
ElasticSearch(2)-安装ElasticSearch
查看>>
从mysql数据表中随机取出一条记录
查看>>
ORACLE 锁表处理,解锁释放session
查看>>
深海机器人问题
查看>>
正则表达式(括号)、[中括号]、{大括号}的区别小结
查看>>
88.NODE.JS加密模块CRYPTO常用方法介绍
查看>>
java.net.ProtocolException: Exceeded stated content-length of: '13824' bytes
查看>>
asp.net 连接 oracle10g 数据库
查看>>
C 入门 第十一节
查看>>
HTML简单的注册页面搭建
查看>>
【06】Vue 之 组件化开发
查看>>
Docker 安装
查看>>
多数据库数据导入
查看>>
[AVR]高压并行编程---基础知识
查看>>
inl文件介绍
查看>>
前端坑--表单篇
查看>>