在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/ 欢迎转载,一起技术交流吧!