with as语法: –针对一个别名
with tmp as (select * from tb_name) –针对多个别名
with
tmp as (select * from tb_name),
tmp2 as (select * from tb_name2),
tmp3 as (select * from tb_name3),
… With查询语句以“WITH”关键字开头,可认为在真正进行查询之前预先构造了一个临时表TT,之后便可多次使用它做进一步的分析和处理 优点:增加了SQL的易读性,如果构造了多个子查询,结构会更清晰;更重要的是:“一次分析,多次使用”,这也是为什么会提供性能的地方,达到了“少读”的目标 例如:现在要从1-20中得到11-14。一般的sql如下:
使用With as 的SQL为:
第一种使用子查询的方法表被扫描了两次,而使用WITH Clause方法,表仅被扫描一次。这样可以大大的提高数据分析和查询的效率
|