• 黔江:1000余亩蓝莓成熟 市民乐享“莓”好时光 2019-05-22
  • 【周展安】重新认识《在延安文艺座谈会上的讲话》的现实意义 2019-05-22
  • 十九大代表卢丽安利用周末与在沪台胞分享她参会心得  2019-05-19
  • (两会受权发布)最高人民法院院长简历 2019-05-14
  • 巫山县大峡村:深度贫困村的脱贫之变 2019-05-12
  • “关注泌尿健康”三金片媒体沙龙北京站 2019-05-09
  • 人民网评:教师欠薪为何又成新闻了? 2019-05-07
  • 涪陵:全国人大代表刘家奇院坝讲“两会” 乡亲点赞“六子致富经” 2019-05-07
  • 海南将与香港携手开拓国际客源市场--旅游频道 2019-05-01
  • 赵孟頫:书法大师是怎么炼成的? 2019-04-28
  • 只看到“贫穷”而看不到“富裕”,只看到贫富差别而看不到其根源是社会财富被个人占为私有的私有制,都是片面错误的。 2019-04-25
  • 紫光阁中共中央国家机关工作委员会 2019-04-25
  • 大众因“排放门”被罚10亿欧元 外媒:处罚还没完 2019-04-11
  • 俄罗斯足球队50横扫沙特队真是让人大饱眼福,特提精神!俄罗斯是战斗民族名不虚传。 2019-04-09
  • 西安启动唐长安城明德门遗址保护工程 2019-04-07
  • 今天看啥
      热点:

        新疆35选7的开奖号 www.ts3ne.com

        使用 Except 和 Intersect,exceptintersect


        做了一个如下的小厕所,如果我需要得到返回是 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 都是返回交叉之后不重复的结果的,这个需要特别注意

         

        新疆35选7的开奖号 www.ts3ne.comtrue//www.ts3ne.com/Sql_Server/1316376.htmlTechArticle使用 Except 和 Intersect,exceptintersect 做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢? A: ; WITH CA AS ( SELECT * FRO...

        相关文章

          暂无相关文章
        相关搜索:

        帮客评论

        视觉看点
      • 黔江:1000余亩蓝莓成熟 市民乐享“莓”好时光 2019-05-22
      • 【周展安】重新认识《在延安文艺座谈会上的讲话》的现实意义 2019-05-22
      • 十九大代表卢丽安利用周末与在沪台胞分享她参会心得  2019-05-19
      • (两会受权发布)最高人民法院院长简历 2019-05-14
      • 巫山县大峡村:深度贫困村的脱贫之变 2019-05-12
      • “关注泌尿健康”三金片媒体沙龙北京站 2019-05-09
      • 人民网评:教师欠薪为何又成新闻了? 2019-05-07
      • 涪陵:全国人大代表刘家奇院坝讲“两会” 乡亲点赞“六子致富经” 2019-05-07
      • 海南将与香港携手开拓国际客源市场--旅游频道 2019-05-01
      • 赵孟頫:书法大师是怎么炼成的? 2019-04-28
      • 只看到“贫穷”而看不到“富裕”,只看到贫富差别而看不到其根源是社会财富被个人占为私有的私有制,都是片面错误的。 2019-04-25
      • 紫光阁中共中央国家机关工作委员会 2019-04-25
      • 大众因“排放门”被罚10亿欧元 外媒:处罚还没完 2019-04-11
      • 俄罗斯足球队50横扫沙特队真是让人大饱眼福,特提精神!俄罗斯是战斗民族名不虚传。 2019-04-09
      • 西安启动唐长安城明德门遗址保护工程 2019-04-07