弥渡县 周至县 上杭县 丹寨县 庄浪县 巫溪县 崇左市 双辽市 张家口市 汾阳市 伊宁县 汝南县 万荣县 镇坪县 将乐县 手机
今天看啥
    热点:
      标签:游网 四川打麻将

      使用 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 都是返回交叉之后不重复的结果的,这个需要特别注意

       

      www.bkjia.comtruehttp://www-bkjia-com.manconsultant.cn/Sql_Server/1316376.htmlTechArticle使用 Except 和 Intersect,exceptintersect 做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢? A: ; WITH CA AS ( SELECT * FRO...

      相关文章

        暂无相关文章
      相关搜索:

      帮客评论

      视觉看点