首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【SQL 为什么sql中,给表起别名后,就不能再使用其真名了】

【SQL 为什么sql中,给表起别名后,就不能再使用其真名了】

作者头像
flos chen
发布2026-01-23 18:42:39
发布2026-01-23 18:42:39
700
举报

在 SQL 中,给表起别名是为了在查询中简化引用,避免表名的重复,或者用于自连接等场景。一旦给表指定了别名,就不能再使用它的原始表名,原因包括:

  1. 避免歧义:在同一个查询中,如果表的别名和原始表名同时使用,会导致歧义,数据库无法确定你引用的是别名还是原始表名。
  2. 保持一致性:SQL 查询要求一致性,一旦表被赋予别名,所有的引用都应该使用这个别名,以保持查询的清晰和一致性。
  3. 简化查询:别名的使用可以简化复杂的查询,特别是当涉及到多表连接时。如果一个表在查询中被多次使用,使用别名可以避免重复写完整的表名。
  4. 遵循 SQL 规则:SQL 语法规则要求一旦表被赋予别名,查询中对该表的所有引用都应该使用这个别名。
  5. 提高可读性:别名通常更简短,使用别名可以提高查询的可读性,使得查询逻辑更加清晰。
  6. 自连接场景:在自连接的场景中,表需要与自身进行连接,此时必须使用别名来区分连接的不同实例。

例如,考虑以下查询:

代码语言:javascript
复制
SELECT employees.name, departments.department_name
FROM employees
JOIN departments ON employees.department_id = departments.id
WHERE employees.salary > 50000;

如果 employees 表被赋予别名 e

代码语言:javascript
复制
SELECT e.name, d.department_name
FROM employees AS e
JOIN departments AS d ON e.department_id = d.id
WHERE e.salary > 50000;

在这个查询中,employeesdepartments 表分别被赋予了别名 ed。在 WHERE 子句中,我们使用 e.salary 而不是 employees.salary,因为 employees 已经通过 AS e 被重命名为 e。如果在查询中再次使用 employees,SQL 将无法识别它,因为它已经通过别名 e 被引用了。

总之,使用别名后不再使用原始表名是为了避免混淆,确保查询的一致性和清晰性,并遵循 SQL 的语法规则。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2026-01-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档