SQL:对表、字段起别名

1、对表起别名

1.1 使用 as

有时候,在对数据库中的表进行操作的时候,发现表名比较冗长,这时候我们就需要对表创建一个别名,别名的关键字为as(也可以不加)

select a.Sno,a.Sname,a.Sage 
from student as a

---
select a.Sno,a.Sname,a.Sage 
from student a (as可以去掉)

我们就对student取了一个别名叫做a

1.2 使用 WITH … AS … 语句增强 SQL 查询的可读性

因为业务比较复杂,所以大家经常会用到各种子查询(sub-query)。于是会写成类似这样:

SELECT
  t1.foo,
  t1.bar,
  t2.baz
FROM (
    SELECT
      foo,
      bar
    FROM
      tb1
    WHERE
      <conditions>
  ) AS t1 INNER JOIN (
    SELECT
      baz
    FROM
      tb2
    WHERE
      <conditions>
  ) AS t2 ON <conditions>
WHERE
  <conditions>;

这样写子查询会有两个问题:

  • 一是子查询的结果如果要在多个不同地方用到,那么就要复制粘贴多次,实际执行的时候也可能执行多次。
  • 二是当子查询 或/和 JOIN 特别多的时候,整个查询就会变得无比复杂,可读性极差。

为解决问题,可用视图(VIEW)解决,也可用 WITH ... AS ... 子句来解决WITH <temprary_table_name> AS (SELECT ... FROM <table_name> WHERE <conds>) 和视图类似,可以创建一个临时表,供之后使用。按上述例子,改用 WITH … AS … 子句可以写成这样:

WITH t1 AS (
  SELECT
    foo,
    bar
  FROM
    tb1
  WHERE
    <conditions>
),
t2 AS (
  SELECT
    baz
  FROM
    tb2
  WHERE
    <conditions>
)

SELECT
  t1.foo,
  t1.bar,
  t2.baz
FROM
  t1 INNER JOIN t2 ON <conditions>
WHERE
  <conditions>;

https://liam.page/2020/03/13/the-WITH-AS-clause-in-Hive-SQL/

2、对字段起别名

在这里插入图片描述
更改后:
在这里插入图片描述

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

还能坚持

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值