zoukankan      html  css  js  c++  java
  • hive (with as)

    背景:
    当我们书写一些结构相对复杂的SQL语句时,可能某个子查询在多个层级多个地方存在重复使用的情况,这个时候我们可以使用 with as 语句将其独立出来,极大提高SQL可读性,简化SQL~
    注:目前 oracle、sql server、hive等均支持 with as 用法,但 mysql并不支持!

    2019-05-31更新:MySQL8.0大量更新优化,支持Common table expressions,即支持 with 语法!

    一、介绍

    with as 也叫做子查询部分,首先定义一个sql片段,该sql片段会被整个sql语句所用到,为了让sql语句的可读性更高些,作为提供数据的部分,也常常用在union等集合操作中。

    with as就类似于一个视图或临时表,可以用来存储一部分的sql语句作为别名,不同的是with as 属于一次性的,而且必须要和其他sql一起使用才可以!

    其最大的好处就是适当的提高代码可读性,而且如果with子句在后面要多次使用到,这可以大大的简化SQL;更重要的是:一次分析,多次使用,这也是为什么会提供性能的地方,达到了“少读”的目标。

    二、使用

    WITH t1 AS (
    SELECT *
    FROM carinfo
    ),
    t2 AS (
    SELECT *
    FROM car_blacklist
    )
    SELECT *
    FROM t1, t2
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    注意:这里必须要整体作为一条sql查询,即with as语句后不能加分号,不然会报错。

    三、注意事项

    1. with子句必须在引用的select语句之前定义,同级with关键字只能使用一次,多个只能用逗号分割;最后一个with 子句与下面的查询之间不能有逗号,只通过右括号分割,with 子句的查询必须用括号括起来.

    以下写法会报错:

    with t1 as (select * from carinfo)
    with t2 as (select * from car_blacklist)
    select * from t1,t2
    1
    2
    3
    with t1 as (select * from carinfo);
    select * from t1
    1
    2
    2.如果定义了with子句,但其后没有跟select查询,则会报错!

    以下写法会报错:

    with t1 as (select * from carinfo)
    1
    正确写法(没有使用 t1没关系,其后有select就行):

    with t1 as (select * from carinfo)
    select * from carinfo
    1
    2
    3.前面的with子句定义的查询在后面的with子句中可以使用。但是一个with子句内部不能嵌套with子句!

    正确写法:

    with t1 as (select * from carinfo),
    t2 as (select t1.id from t1)
    select * from t2
    ————————————————
    版权声明:本文为CSDN博主「深寒丶」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/Abysscarry/article/details/81322669

  • 相关阅读:
    Java 验证码工具类
    Servlet实现文件下载
    SQLyog连接报错 Error No.2058 Plugin caching_sha2_password could not be loaded
    springmvc上传文件出现异常,postman测试,文件上传问题org.springframework.web.HttpMediaTypeNotSupportedException: Content type 'multipart/form-data;
    swaager2中实现文件上传的api测试操作
    idea中无法正常显示java与jsp文件内容
    servlet容器多线程与spring单例
    ThreadLocal使用与注意事项
    mysql的分组之后取时间最大的时间的那个数据
    servlet中常见装饰类HttpServletRequestWrapper等等
  • 原文地址:https://www.cnblogs.com/jeasonit/p/11600083.html
Copyright © 2011-2022 走看看