MySQL数据库语句中的表别名、列别名存在空格,我们应该注意什么?

在MySQ数据库中,我们操作DML语句,涉及到比较复杂的逻辑,就会对相应的表、列取别名(“外号”),当然为了提高语句的可读性,我们取名也要“见名知意”。列别名:如果别名中无空格等,可以省略双引号,如有空格等,不能省略双引号;表别名:不能加双引号,表中的别名不要中间有空格等,尽量简洁命名

测试表数据:
mysql> select * from t_department;
+-----+--------+------------------+
| did | dname  | description      |
+-----+--------+------------------+
|   1 | 开发部       | 负责后台开发工作 |
|   2 | 前端部     | 负责前端开发工作   |
|   3 | 运维部      | 负责服务运营工作  |
|   4 | 客户部      | 负责需求服务工作 |
|   5 | 测试部      | 负责测试工作     |
+-----+--------+------------------+
5 rows in set (0.00 sec)
1.列别名

(1)正常列取别名,分别对did、dname、description取名,并且用引号标识。

mysql> SELECT did AS "部门编号" ,dname AS "部门名称" , description AS "部门描述" FROM t_department;
+----------+----------+------------------+
| 部门编号  | 部门名称   | 部门描述          |
+----------+----------+------------------+
|        1 | 开发部     | 负责后台开发工作   |
|        2 | 前端部     | 负责前端开发工作   |
|        3 | 运维部     | 负责服务运营工作   |
|        4 | 客户部     | 负责需求服务工作   |
|        5 | 测试部      | 负责测试工作     |
+----------+----------+------------------+
5 rows in set (0.00 sec)

(2)列取别名,在双引号的别名加空格正常输出,第一列中的“部门”与“编号”存在空格

mysql> SELECT did AS "部门  编号" ,dname AS "部门名称" , description AS "部门描述" FROM t_department;
+------------+----------+------------------+
| 部门  编号  | 部门名称   | 部门描述          |
+------------+----------+------------------+
|          1 | 开发部    | 负责后台开发工作    |
|          2 | 前端部    | 负责前端开发工作    |
|          3 | 运维部    | 负责服务运营工作    |
|          4 | 客户部    | 负责需求服务工作    |
|          5 | 测试部    | 负责测试工作        |
+------------+----------+------------------+
5 rows in set (0.00 sec)

(3)列取别名,无双引号的别名加空格会报错,第一列中的“部门”与“编号”存在空格

mysql> SELECT did AS 部门  编号 ,dname AS 部门名称 , description AS 部门描述 FROM t_department;

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your

ear '编号 ,dname AS 部门名称 , description AS 部门描述 FROM t_department' at line 1

mysql>
2.表别名

(1)表取别名时,不能加双引号

mysql> SELECT testname.did,testname.dname,testname.description FROM t_department AS testname;
+-----+--------+------------------+
| did | dname  | description      |
+-----+--------+------------------+
|   1 | 开发部       | 负责后台开发工作 |
|   2 | 前端部     | 负责前端开发工作  |
|   3 | 运维部      | 负责服务运营工作 |
|   4 | 客户部      | 负责需求服务工作 |
|   5 | 测试部      | 负责测试工作    |
+-----+--------+------------------+
5 rows in set (0.00 sec)

(2)表取别名时,加双引号,就会报错

mysql> SELECT testname.did,testname.dname,testname.description FROM t_department AS "testname";
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use n
ear '"testname"' at line 1
mysql>
小结:

  可见,列别名、表别名对双引号的标识符是严格要求,所以我们注意SQL语法细节,当然在取别名时AS甚至双引号都能去掉,正常查询,如下语句,但是有空格就会报错 ,所以我平时就按照 <列/表 AS “别名”>这种形式编写就行,靠谱~

SELECT did  部门编号 ,dname  部门名称 , description 部门描述 FROM t_department;
#轻松一刻:

在这里插入图片描述


  ☝上述分享来源个人总结,如果分享对您有帮忙,希望您积极转载;如果您有不同的见解,希望您积极留言,让我们一起探讨,您的鼓励将是我前进道路上一份助力,非常感谢!我会不定时更新相关技术动态,同时我也会不断完善自己,提升技术,希望与君同成长同进步!

☞本人博客:https://coding0110lin.blog.csdn.net/  欢迎转载,一起技术交流吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值