等值连接
多表直接的列值对应相等
SELECT employees.employee_id, employees.last_name,
employees.department_id, departments.department_id,
departments.location_id
FROM employees, departments
WHERE employees.department_id = departments.department_id;
:::info 建议:从 SQL 优化的角度,建议多表查询时,每个字段前都指明其所在的表 :::
非等值连接
多表直接的列值对应不相等
SELECT e.last_name, e.salary, j.grade_level
FROM employees e, job_grades j
WHERE e.salary BETWEEN j.lowest_sal AND j.highest_sal;
多表查询规范
多个连接条件使用 AND 操作符
SELECT employees.employee_id, employees.last_name,
employees.department_id, departments.location_id
FROM employees, departments,locations
WHERE employees.department_id = departments.department_id;
AND departments.locations_id = locations.location_id
:::warning 注意:如果有 n 个表实现多表查询,则需要至少 n-1 个连接条件 :::
区分重复的列名:多个表中有相同列时,必须在列名之前加上表名前缀。在不同表中具有相同列名的列可以用表名加以区分。
表的别名:如果表名过长,影响语句的阅读性,可以给表起别名:
SELECT emp.employee_id, emp.last_name,
emp.department_id, dept.department_id,
dept.location_id
FROM employees emp, departments dept
WHERE emp.department_id = dept.department_id;
:::warning 注意:但如果起了别名就需要在 SELECT 和 WHERE 全部使用别名,不能使用原来的表名,原因是 FROM 之后别名就覆盖了原表名,导致原表名不能使用 :::
阿里开发规范
【强制】对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或表名)进行限定。
说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表名),并且操作列在多个表中存在时,就会抛异常。
正例:select t1.name from table_first as t1
,table_second as t2 where t1.id=t2.id;
反例:在某业务中,由于多表关联查询语句没有加表的别名(或表名)的限制,正常运行两年后,最近在某个表中增加一个同名字段,在预发布环境做数据库变更后,线上查询语句出现出 1052 异常:Column ‘name’ in field list is ambiguous。