zoukankan      html  css  js  c++  java
  • 使用 Except 和 Intersect

    做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢?

    A:

    ;WITH CA AS(
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('d'))a (A))
    ,CB AS (
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('f'))a (A)
    )
    SELECT * FROM CA
    EXCEPT SELECT * FROM CB
    UNION 
    SELECT * FROM CB
    EXCEPT SELECT * FROM CA

    B:

    ;WITH CA AS(
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('d'))a (A))
    ,CB AS (
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('f'))a (A)
    )
    SELECT * FROM CA
    EXCEPT SELECT * FROM CB
    UNION 
    (SELECT * FROM CB
    EXCEPT SELECT * FROM CA)

     C:

    ;WITH CA AS(
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('d'))a (A))
    ,CB AS (
    SELECT *
        FROM (VALUES('a'),('b'),('c'),('f'))a (A)
    )
    (SELECT * FROM CA
    EXCEPT SELECT * FROM CB)
    UNION 
    (SELECT * FROM CB
    EXCEPT SELECT * FROM CA)

     实际情况执行一下就知道,其实BC 的语句都可以执行。而A的执行情况就是只返回了 d。这个其实是跟select 的执行顺序有关的。

    通常我们看select 的执行顺序的时候,可能会忽略这2个不常用的连接谓词导致误判。这里做一个实验就可以发现,其实 Except(Intersect 同理) 的查询优先级是和 union 或者union all 是同级的。

    所以遵循从左到右的顺序,如果不用括号改变执行顺序,从上面的例子,将会返回  CA Except CB -> Union CB -> Except CA 的执行结果。也就是一个容易忽略的位置。

    因为比较少用,所以我也躺枪了。在此分享一波,希望大家不要踩坑。

    PS

    1 select 执行顺序的地址 :https://docs.microsoft.com/zh-cn/sql/t-sql/queries/select-transact-sql

    2 Except 和 Intersect 都是返回交叉之后不重复的结果的,这个需要特别注意

  • 相关阅读:
    我在互联网的第一年
    变速变调原理与方法总结
    TIMIT语音库
    基于HTK语音工具包进行孤立词识别的使用教程
    Praat 音频分析 人工标注
    HTK源码学习总结
    HTK搭建语音拨号系统实验材料下载
    应用HTK搭建语音拨号系统4: 识别器评估
    应用HTK搭建语音拨号系统3:创建绑定状态的三音素HMM模型
    应用HTK搭建语音拨号系统2:创建单音素HMM模型
  • 原文地址:https://www.cnblogs.com/Gin-23333/p/8674562.html
Copyright © 2011-2022 走看看