Hive中with…as…的用法

释放双眼,带上耳机,听听看~!
Hive中使用 with as 优化SQL

抛出问题:

当我们书写一些结构相对复杂的SQL语句时,可能某个子查询在多个层级多个地方存在重复使用的情况,这个时候我们可以使用 with as 语句将其独立出来,极大提高SQL可读性,简化SQL~

with as简介

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

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

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

语法限制

  1. with...as...必须和其他sql一起使用(可以定义一个with但在后续语句中不使用他)
  2. with...as...是一次性的

如何使用

WITH t1 AS (SELECT * FROM carinfo),   
t2 AS (SELECT * FROM car_blacklist)
SELECT * FROM t1, t2

注意:这里必须要整体作为一条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
with t1 as (select * from carinfo);
select * from t1

2. 如果定义了with子句,但其后没有跟select查询,则会报错!

以下写法会报错:

with t1 as (select * from carinfo)

正确写法(没有使用 t1没关系,其后有select就行):

with t1 as (select * from carinfo)
select * from carinfo

3. 前面的with子句定义的查询在后面的with子句中可以使用。

正确写法:

with t1 as (select * from carinfo),
t2 as (select t1.id from t1)
select * from t2

4. with...as...当然是可以嵌套的,此处举一个简单例子

with temp2 as (
    with temp1 as (
        select * from xxx
    )
    select * from temp1
)
select * from temp2;

本文参考:https://cloud.tencent.com/developer/article/1644701,但原文中“一个with子句内部不能嵌套with子句”的说法不准确,with可以嵌套。

给TA打赏
共{{data.count}}人
人已打赏
SQL

Hive中rlike,like,not like的区别与使用详解

2021-11-5 16:12:54

Excel

用公式提取Excel单元格中的汉字

2018-3-27 22:32:35

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索