等值连接

多表直接的列值对应相等
1554975496900.png

  1. SELECT employees.employee_id, employees.last_name,
  2. employees.department_id, departments.department_id,
  3. departments.location_id
  4. FROM employees, departments
  5. WHERE employees.department_id = departments.department_id;

:::info 建议:从 SQL 优化的角度,建议多表查询时,每个字段前都指明其所在的表 :::

非等值连接

多表直接的列值对应不相等
1554978442447.png

  1. SELECT e.last_name, e.salary, j.grade_level
  2. FROM employees e, job_grades j
  3. WHERE e.salary BETWEEN j.lowest_sal AND j.highest_sal;

image.png

多表查询规范

多个连接条件使用 AND 操作符

  1. SELECT employees.employee_id, employees.last_name,
  2. employees.department_id, departments.location_id
  3. FROM employees, departments,locations
  4. WHERE employees.department_id = departments.department_id;
  5. AND departments.locations_id = locations.location_id

:::warning 注意:如果有 n 个表实现多表查询,则需要至少 n-1 个连接条件 :::

区分重复的列名:多个表中有相同列时,必须在列名之前加上表名前缀。在不同表中具有相同列名的列可以用表名加以区分。

表的别名:如果表名过长,影响语句的阅读性,可以给表起别名:

  1. SELECT emp.employee_id, emp.last_name,
  2. emp.department_id, dept.department_id,
  3. dept.location_id
  4. FROM employees emp, departments dept
  5. WHERE emp.department_id = dept.department_id;

:::warning 注意:但如果起了别名就需要在 SELECT 和 WHERE 全部使用别名,不能使用原来的表名,原因是 FROM 之后别名就覆盖了原表名,导致原表名不能使用 :::

阿里开发规范
【强制】对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或表名)进行限定。

说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表名),并且操作列在多个表中存在时,就会抛异常。

正例:select t1.name from table_first as t1table_second as t2 where t1.id=t2.id;

反例:在某业务中,由于多表关联查询语句没有加表的别名(或表名)的限制,正常运行两年后,最近在某个表中增加一个同名字段,在预发布环境做数据库变更后,线上查询语句出现出 1052 异常:Column ‘name’ in field list is ambiguous。