zoukankan      html  css  js  c++  java
  • SQL中EXCEPT和Not in的区别?

    初始化两张表:

    CREATE TABLE tb1(ID int)  INSERT tb1          SELECT NULL UNION  ALL          SELECT NULL UNION  ALL          SELECT NULL UNION  ALL          SELECT 1 UNION  ALL          SELECT 2 UNION  ALL          SELECT 2 UNION  ALL          SELECT 2 UNION  ALL          SELECT 3 UNION  ALL          SELECT 4 UNION  ALL          SELECT 4

     

    CREATE TABLE tb2(ID int)

    INSERT tb2        SELECT NULL

    UNION  ALL          SELECT 1

    UNION  ALL          SELECT 3

    UNION  ALL          SELECT 4

    UNION  ALL          SELECT 4

     A:

    SELECT * FROM tb1

    SELECT * FROM tb2

     

    SELECT * FROM tb1 EXCEPT SELECT * FROM tb2;

    SELECT * FROM tb1 WHERE id NOT IN(SELECT id FROM tb2);--得不到任何值

    结果:

    B、我先删除表tb1的是NULL值的行

    --DELETE FROM tb1 where id is null

    B、

    SELECT * FROM tb1 EXCEPT SELECT * FROM tb2;

    SELECT * FROM tb1 WHERE id NOT IN(SELECT id FROM tb2);--得不到任何值

    结果:同上A

    C、把表tb2的是NULL值的行也删除

    --DELETE FROM tb2 where id is null

    C、

     

     

    SELECT * FROM tb1 EXCEPT SELECT * FROM tb2;

    SELECT * FROM tb1 WHERE id NOT IN(SELECT id FROM tb2);

    结果:

    这是两张表中都没有NULL值时,得到的结果;

    D、在tb1表中插入一条NULL值

    D、

     

    SELECT * FROM tb1 EXCEPT SELECT * FROM tb2;

    SELECT * FROM tb1 WHERE id NOT IN(SELECT id FROM tb2);

    结果:

    以上例子说明: 

    except会去重复, not in 不会(除非你在select中显式指定)

    except用于比较的列是所有列, 除非写子查询限制列, not in 没有这种情况

    表tb2中如果有null值的话,not in查询得不到值(如:A、B)

    表tb1中如果有null值,not in不会查询出这个null值(如:D),而except可以查询到

    当然通过对子查询指定不为NULL的话,NOT IN自然会得到值,如:

    SELECT * FROM tb1 WHERE id NOT IN(SELECT id FROM tb2 WHERE ID IS NOT NULL);

    这里是需要注意的,如果你的字段运行为NULL,又欲使用NOT IN那么就需要这么做

  • 相关阅读:
    About Us
    WeCenter 社交化问答社区程序 | WeCenter 是一款知识型的社交化问答社区程序,专注于社区内容的整理、归类、检索和再发行
    C++的Json解析库:jsoncpp和boost
    c++
    牛黄上清片_百度百科
    python中multiprocessing.pool函数介绍_正在拉磨_新浪博客
    What’s New in Python 2.7 — Python 3.4.0b2 documentation
    What’s New in Python 2.7 — Python 3.4.0b2 documentation
    掌阅科技(ireader)年薪25w—45w 诚聘python高手,如果很牛可再议
    Vedis
  • 原文地址:https://www.cnblogs.com/jijm123/p/9799471.html
Copyright © 2011-2022 走看看