MySQL中使用表别名与字段别名

MySQL 表别名(Alias)
SQL 表别名
在 SQL 语句中,可以为表名称及字段(列)名称指定别名(Alias),别名是 SQL 标准语法,几乎所有的数据库系统都支持。通过关键字 AS 来指定。
表别名语法:
SELECT column FROM table AS table_alias
上述 SQL 执行后的效果,给人感觉是对 table_alias 表进行查询,但实际上对单表做简单的别名查询通常是无意义的。一般是对一个表要当作多个表来操作,或者是对多个表进行操作时,才设置表别名。
下面是一个简单的多表操作的例子:
article 文章表: aid title content uid pubtime
user 用户表: uid username password email regdate
当查询一篇文章的时候,一般会同时将对应的文章作者查询出来,通常的 SQL 语句为:
SELECT article.title,article.content,user.username FROM article, user
WHERE article.aid=1 AND article.uid=user.uid
设置表别名后:
SELECT a.title,a.content,u.username FROM article AS a, user AS u where a.aid=1 and a.uid=u.uid
上述两条 SQL 语句查询结果是一样的
可以看出,使用表别名查询,可以使 SQL 变得简洁而更易书写和阅读,尤其在 SQL 比较复杂的情况下。除了使用别名来简化 SQL 外,有些时候例如一个表做自身关联时,必须要使用别名来当作两个表进行关联操作。
MySQL 字段别名(列别名)
SQL 字段别名
同本文前文讲述的表别名一样,SQL(MySQL) 也支持对表的字段(列)设置别名。
字段别名语法:
SELECT column AS column_alias FROM table
字段别名使用例子
字段别名一个明显的效果是可以自定义查询数据返回的字段名。
在查询的时候,对 username 字段使用别名:
SELECT username AS name,email FROM user
当然如此简单的定义字段的别名是没有太大实际意义的,字段别名更多的意义是解决字段名的重复,如一个表字段被查询两次或更多次时:
SELECT username AS name,username,email FROM user
或者两个及更多表进行查询,有相同的返回字段时:
两个表都定义了 title 字段且都需要返回该字段数据时,就需要定义字段别名(至少定义一个):
SELECT a.title AS atitle,u.username,u.title AS utitle FROM article AS a, user AS u where a.uid=u.uid
可以看出,当查询返回的字段名称相同时,可以通过定义别名来避免冲突,上面查询的例子同时定义了字段别名与表别名。
提示
通常,定义字段别名的 AS 关键字可以省略,即下面两句 SQL 效果一致:
SELECT username AS name FROM user
SELECT username name FROM user
但我们建议不要省略 AS 关键字。
别名(alias)是 SQL 的标准语法,几乎所有的数据库系统都支持。在处理一些复杂的查询时,可以合理的定义表和字段别名来使 SQL 语句看起来更加精简易读,也避免查询返回相同字段数据时的冲突。

有如下sql语句:
【案例1】
   SELECT userName AS a,  userAddress AS b FROM TestTableWHEREalike’%am%’ 
该语句执行是会报错,因为别名只是对字段的一种引用,不能当作字段一样使用,如果真要把别名当字段一样使用,可以如下变通:
   SELECT a, b
   FROM(
      SELECT userName AS a,  userAddress AS b FROM TestTable
   ) AS tempTable 
   WHERE a like ‘%dd%’ 
   如此,便可把别名当字段一样使用了
但是需要和足以紫色字体部分,该处要给内嵌的select查询指定一个别名,否则会报错

【案例2】
   SELECT coutDay AS a, month1 AS b,  (select 信用天数 from PayDays where 自定义值 = month1) AS c,  (a+ c) AS ‘total’ FROM TestTable
变通为:
   SELECT a, b, a + c AS  ‘total’ 
   FROM(
      SELECT coutDay AS a, month1 AS b,  (select 信用天数 from PayDays where 自定义值 = month1) AS c FROM TestTable
   ) AS tempTable

【案例3】
下面的sql语句中中,灰色部分重复了两次,第二个灰色部分有不能用第一个灰色区域的别名CountDays替换,一旦替换会出现语法错误。

SELECT 
cCustCode As 客户代码,
cPayWay As 付款条件,  
cPayCode As 付款方式,
CASE
WHEN cPayWay like ‘%月结%’ THEN (datediff(day, dOutDate, dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,dOutDate)+1, 0))) + (select 信用天数 from PayDays where 自定义值 = cPayWay))
ELSE (select 信用天数 from PayDays where 自定义值 = cPayWay)
END As CountDays,
Convert(Varchar(12),dOutDate, 102) As 出库日期,
Convert(Varchar(12),DateAdd(Day, Cast(
(CASE
WHEN cPayWay like ‘%月结%’ THEN (datediff(day, dOutDate, dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,dOutDate)+1, 0))) + (select 信用天数 from PayDays where 自定义值 = cPayWay))
ELSE (select 信用天数 from PayDays where 自定义值 = cPayWay)
END) AS int), dOutDate), 102) AS  实际回款日期
FROM ODS.F_DISPATCHLIST_ALL
where (isum-isnull(nSumARAmt,0))>10e-8

我们把第二个灰色部分提出来,改为

SELECT 客户代码,付款条件,  付款方式,CountDays,出库日期,Convert(Varchar(12),DateAdd(Day, Cast(CountDays)AS int), dOutDate), 102)AS  实际回款日期 
FROM(
SELECT 
cCustCode As 客户代码,
cPayWay As 付款条件,  
cPayCode As 付款方式,
CASE
WHEN cPayWay like ‘%月结%’ THEN (datediff(day, dOutDate, dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,dOutDate)+1, 0))) + (select 信用天数 from PayDays where 自定义值 = cPayWay))
ELSE (select 信用天数 from PayDays where 自定义值 = cPayWay)
END As CountDays,
Convert(Varchar(12),dOutDate, 102) As 出库日期
FROM ODS.F_DISPATCHLIST_ALL
where (isum-isnull(nSumARAmt,0))>10e-8 
)

猜你喜欢

转载自blog.csdn.net/qq_41906344/article/details/82957852