• 人民网评:涉及群众利益的事,必须“马上就办” 2019-04-25
  • 胡世忠在泰和调研经济运行和项目建设 2019-04-25
  • “基因魔剪”安全性再遭质疑 2019-04-23
  • 女孩面试“女二号”,车内试戏被脱裤子 2019-04-22
  • 财政部:对原产于美国的500亿美元进口商品加征关税 2019-04-18
  • 李白是哪一种书法家? 2019-04-10
  • 重庆夜色让人如此沉醉文章中国国家地理网 2019-04-04
  • 男子高速酒驾飞出立交桥 车身粉碎人无碍 2019-03-30
  • 成都康弘药业集团股份有限公司董事长柯尊洪获第十二届人民企业社会责任奖年度人物奖 2019-03-30
  • 驻最高检纪检组健全廉政档案 力求精准"画像" 2019-03-27
  • 游客被指捡石子砸老虎 北京野生动物园:正在核实 2019-03-27
  • 10月26日十九大新闻发言人专题新闻发布会 2019-03-22
  • 多交140分“亚裔税”?哈佛大学被控歧视亚裔学生 2019-03-22
  • 男子农田挖到古董抠出吓得魂飞魄散 2019-03-17
  • 瑞典南部城市发生枪击案致5人伤 警方:与恐袭无关 2019-03-10
  • 今天看啥
      热点:

        北京赛车pk10历史记录 www.zwahn.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 都是返回交叉之后不重复的结果的,这个需要特别注意

         

        北京赛车pk10历史记录 www.zwahn.comtrue//www.zwahn.com/Sql_Server/1316376.htmlTechArticle使用 Except 和 Intersect,exceptintersect 做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢? A: ; WITH CA AS ( SELECT * FRO...

        相关文章

          暂无相关文章
        相关搜索:

        帮客评论

        视觉看点
      • 人民网评:涉及群众利益的事,必须“马上就办” 2019-04-25
      • 胡世忠在泰和调研经济运行和项目建设 2019-04-25
      • “基因魔剪”安全性再遭质疑 2019-04-23
      • 女孩面试“女二号”,车内试戏被脱裤子 2019-04-22
      • 财政部:对原产于美国的500亿美元进口商品加征关税 2019-04-18
      • 李白是哪一种书法家? 2019-04-10
      • 重庆夜色让人如此沉醉文章中国国家地理网 2019-04-04
      • 男子高速酒驾飞出立交桥 车身粉碎人无碍 2019-03-30
      • 成都康弘药业集团股份有限公司董事长柯尊洪获第十二届人民企业社会责任奖年度人物奖 2019-03-30
      • 驻最高检纪检组健全廉政档案 力求精准"画像" 2019-03-27
      • 游客被指捡石子砸老虎 北京野生动物园:正在核实 2019-03-27
      • 10月26日十九大新闻发言人专题新闻发布会 2019-03-22
      • 多交140分“亚裔税”?哈佛大学被控歧视亚裔学生 2019-03-22
      • 男子农田挖到古董抠出吓得魂飞魄散 2019-03-17
      • 瑞典南部城市发生枪击案致5人伤 警方:与恐袭无关 2019-03-10