当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL中使用表别名与字段别名的基本教程

MySQL中使用表别名与字段别名的基本教程

2017年12月12日  | 移动技术网IT编程  | 我要评论

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

select column from table as table_alias

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

20151216165438787.png (648×102)

user 用户表:

20151216165457306.png (644×105)

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

20151216165514636.png (655×57)

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

mysql 字段别名(列别名)
sql 字段别名
同本文前文讲述的表别名一样,sql(mysql) 也支持对表的字段(列)设置别名。
字段别名语法:

select column as column_alias from table

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

20151216165531485.png (647×103)

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

select username as name,email from user

返回查询结果如下:

20151216165550742.png (640×110)

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

select username as name,username,email from user

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

20151216165606501.png (652×108)

user 用户表:

20151216165636638.png (645×104)

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

select a.title as atitle,u.username,u.title as utitle from article as a, user as u where a.uid=u.uid

返回查询结果如下:

20151216165652332.png (650×108)

可以看出,当查询返回的字段名称相同时,可以通过定义别名来避免冲突,上面查询的例子同时定义了字段别名与表别名。
提示
通常,定义字段别名的 as 关键字可以省略,即下面两句 sql 效果一致:

select username as name from user
select username name from user

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网