zoukankan      html  css  js  c++  java
  • MYSQL IN 与 EXISTS 的优化示例

    文章转载自:http://www.jb51.net/article/53127.htm

    当B表的数据集必须小于A表的数据集时,用in优于exists,当A表的数据集系小于B表的数据集时,用exists优于in

    优化原则:小表驱动大表,即小的数据集驱动大的数据集。

    ############# 原理 (RBO) #####################

    1
    2
    3
    4
    select * from A where id in (select id from B)
    等价于:
    for select id from B
    for select * from A where A.id = B.id

    当B表的数据集必须小于A表的数据集时,用in优于exists。

    1
    2
    3
    4
    select * from A where exists (select 1 from B where B.id = A.id)
    等价于
    for select * from A
    for select * from B where B.id = A.id

    当A表的数据集系小于B表的数据集时,用exists优于in。

    注意:A表与B表的ID字段应建立索引。

    例如:

    1
    2
    3
    4
    /** 执行时间:0.313s **/
    SELECT SQL_NO_CACHE * FROM rocky_member m WHERE EXISTS (SELECT 1 FROM rocky_vip_appro a WHERE m.ID = a.user_id AND a.passed = 1);
    /** 执行时间:0.160s **/
    SELECT SQL_NO_CACHE * FROM rocky_member m WHERE m.ID in(SELECT ID FROM rocky_vip_appro WHERE passed = 1);

    not in 和not exists用法类似。

  • 相关阅读:
    HashMap和Hashtable的区别
    java倒计时三种简单实现方式
    AngularJS---基本操作
    AngularJS---认识AngularJS
    Java线程面试题
    JAVA中高访问量高并发的问题怎么解决?
    Java高并发,如何解决,什么方式解决
    Map总结
    Github
    反射
  • 原文地址:https://www.cnblogs.com/cl1234/p/5641401.html
Copyright © 2011-2022 走看看