mysql是否支持别名_MySQL中使用表别名与字段别名的基本教程

MySQL 表别名(Alias)SQL 表别名

在 SQL 语句中,可以为表名称及字段(列)名称指定别名(Alias),别名是 SQL 标准语法,几乎所有的数据库系统都支持。通过关键字 AS 来指定。

表别名语法:

SELECT column FROM table AS table_alias

上述 SQL 执行后的效果,给人感觉是对 table_alias 表进行查询,但实际上对单表做简单的别名查询通常是无意义的。一般是对一个表要当作多个表来操作,或者是对多个表进行操作时,才设置表别名。

表别名使用例子

下面是一个简单的多表操作的例子:

article 文章表:

76cbee65d163f01726de788226e4f7e9.png

user 用户表:

74d543e49137c0ac67ee2d1be46420bf.png

当查询一篇文章的时候,一般会同时将对应的文章作者查询出来,通常的 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 语句查询结果是一样的:

4c4d672eb6b38e251c26eeeb41846b7a.png

可以看出,使用表别名查询,可以使 SQL 变得简洁而更易书写和阅读,尤其在 SQL 比较复杂的情况下。除了使用别名来简化 SQL 外,有些时候例如一个表做自身关联时,必须要使用别名来当作两个表进行关联操作。

MySQL 字段别名(列别名)SQL 字段别名

同本文前文讲述的表别名一样,SQL(MySQL) 也支持对表的字段(列)设置别名。

字段别名语法:

SELECT column AS column_alias FROM table

字段别名使用例子

字段别名一个明显的效果是可以自定义查询数据返回的字段名。如下面的表数据:

user 用户表:

455e21bf834fb984ae19ca89f941bc29.png

在查询的时候,对 username 字段使用别名:

SELECT username AS name,email FROM user

返回查询结果如下:

f9c36e847b515bbd21ea542a3252f415.png

当然如此简单的定义字段的别名是没有太大实际意义的,字段别名更多的意义是解决字段名的重复,如一个表字段被查询两次或更多次时:

SELECT username AS name,username,email FROM user

或者两个及更多表进行查询,有相同的返回字段时:

article 文章表:

55c32325d5da744ec3d1f1a69fa53682.png

user 用户表:

b7f56aacacdb2c0fba06efa8b3f58100.png

上面两个表都定义了 title 字段且都需要返回该字段数据时,就需要定义字段别名(至少定义一个):

SELECT a.title AS atitle,u.username,u.title AS utitle FROM article AS a, user AS u where a.uid=u.uid

返回查询结果如下:

6b4d9cce8ceaaad5806431fe1558f6bb.png

可以看出,当查询返回的字段名称相同时,可以通过定义别名来避免冲突,上面查询的例子同时定义了字段别名与表别名。

提示

通常,定义字段别名的 AS 关键字可以省略,即下面两句 SQL 效果一致:

SELECT username AS name FROM user

SELECT username name FROM user

但我们建议不要省略 AS 关键字。

别名(alias)是 SQL 的标准语法,几乎所有的数据库系统都支持。在处理一些复杂的查询时,可以合理的定义表和字段别名来使 SQL 语句看起来更加精简易读,也避免查询返回相同字段数据时的冲突。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值