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

列别名:如果别名中无空格等,可以省略双引号,如有空格等,不能省略双引号表别名:不能加双引号,表中的别名不要中间有空格等,尽量简洁命名测试表数据:mysql&gt; select * from t_department;+-----+--------+------------------+| did | dname | description |+-----+------...
mysql别名使用问题 本内容来源于官方文档 英文不错的同学可以直接到文档 https://dev.mysql.com/doc/refman/8.0/en/problems-with-alias.html 别名用的位置 可以在查询选择使用别名来为指定不同的名称,可以在GROUP BY,ORDER BY, HAVING,where使用别名 使用时的问题 -- 获取每一个部门的平均薪资 -- 别名带引号 select did as "d",avg(salary) from t_employ
给字段、别名的关键字as 在使用SQL语句显示结果的时候,往往在屏幕显示的字段名并不具备良好的可读性,此时可以使用 as 给字段起一个别名。 1.使用as给字段起别名 使用as之前: select id, name, gender from students; 使用as之后: select id as 序号, name as 名字, gender as 性别 from students;
mysql进行select的时候,间有空格,如果这时候直接select columnNames,columnNames from tableName是不行的,需要加上反引号把每个名括起来才可以,反引号就是想单引号的那个在esc下面的跟波浪线号在一起的那个符号`` ,有人说这种情况是加[],我试了一下在mysql里是不可以的,可能是用在别的sql语句里,等有机会再试。 转载于:h...
SELECT e.employee_id, e.first_name, d.department_name FROM employees AS e JOIN departments AS d ON e.department_id = d.department_id; 这个查询语句,`employees`被设置为别名`e`,`departments`被设置为别名`d`。通过使用别名,我们可以在查询语句更方便地引用,并且可以避免名冲突的问题。
【注解问题】Swagger-ui.html启动报错:Unable to infer base url. This is common when using dynamic servlet.. 12344 【注解问题】Spring Boot项目启动报错:nested exception is org.springframework.beans.factory.UnsatisfiedDependen... 成功解决debug时报错:The source attachment does not contain the source for the file DelegatingMethodAcces... 鹧鸪飞819: 您好,经过上述操作以后还是相同的debug报错 【注解问题】Swagger-ui.html启动报错:Unable to infer base url. This is common when using dynamic servlet.. 乾淨俐落: 闭着眼睛说呢 【注解问题】Swagger-ui.html启动报错:Unable to infer base url. This is common when using dynamic servlet.. 当下就是最好: 感谢,有帮助,点赞 Windows下如何批量修改文件后缀名(.doc.pdf.html...)? 天下。168: 请问如果我要改成utf8的txt怎么改呢,现在只能改成ANSI的txt表情包 Vscode终端运行node命令,提示“'node' 不是内部或外部命令,也不是可运行的程序或批处理文件。”怎么回事? HwKZ9812: 下载node.js然后配置好环境变量重启vscode就好了呀,不需要设置这个