文章目录
- 1. MySQL关键字—using和on
- 1.1 using关键字的概念
- 2. using和on的区别
- 2.1 USING 子句
- 2.2 ON 子句
- 3. 示例对比
- 3.1 建表:
- 3.2 准备数据
- 3.3 结果
1. MySQL关键字—using和on
1.1 using关键字的概念
连接查询时如果是同名字段作为连接条件,using可以代替on出现(比on更好),using是针对同名字段(using(id)===on A.id=B.id),using关键字使用后会自动合并对应字段为一个,using可以同时使用多个字段作为条件。
JavaScript中的==
和===
双等号(==)
只比较值是否相等。它本质上是做类型转换。这意味着在比较数值之前,它将变量的类型转换为相互匹配。三等号(===)
不执行类型转换。它将验证被比较的变量是否具有相同的值和相同的类型。
使用 USING
和 ON
子句在 SQL 中进行 JOIN
操作时,它们的主要区别在于指定连接条件的方式,下面是两种方法的对比。
2. using和on的区别
2.1 USING 子句
USING
子句用于指定两个表之间具有相同名称和数据类型的列作为连接条件。- 它是一种简写形式,适用于两个表在指定列上具有完全相同的列名和数据类型。
- 语法更简洁,避免了重复列名。
优点:
- 代码更简洁,易于阅读和维护。
缺点:
- 限制性较高,只能用于具有相同名称和数据类型的列。
- 如果需要连接多个列或列名不匹配,不能使用
USING
。
2.2 ON 子句
ON
子句用于指定两个表之间的连接条件,可以是任意的比较表达式。- 它不要求列名相同,只要两个表中的列可以进行比较即可。
- 可以用于更复杂的连接条件,如连接多个列或使用不同的列名。
优点:
- 灵活性高,可以指定任何比较表达式作为连接条件。
- 适用于列名不同或需要连接多个列的情况。
缺点:
- 语法可能更复杂,特别是在涉及多个列或列名不匹配时。
3. 示例对比
假设我们有两个表 employees
和 departments
,它们都有一个共同的列 department_id
:
3.1 建表:
-- 创建 employees 表
CREATE TABLE employees (
employee_id INT PRIMARY KEY,
name VARCHAR(100),
department_id INT
);
-- 创建 departments 表
CREATE TABLE departments (
department_id INT PRIMARY KEY,
department_name VARCHAR(100)
);
3.2 准备数据
-- 向 employees 表插入数据
INSERT INTO employees (employee_id, name, department_id) VALUES
(1, 'Alice', 1),
(2, 'Bob', 2),
(3, 'Charlie', 1),
(4, 'David', 3);
-- 向 departments 表插入数据
INSERT INTO departments (department_id, department_name) VALUES
(1, 'HR'),
(2, 'Marketing'),
(3, 'Engineering');
使用 USING
的 JOIN
示例:
SELECT e.name, d.department_name
FROM employees e
JOIN departments d USING (department_id);
使用 ON
的 JOIN
示例:
SELECT e.name, d.department_name
FROM employees e
JOIN departments d ON e.department_id = d.department_id;
3.3 结果
在这个例子中,两种方法都能达到相同的结果,但 USING
子句更为简洁。如果 employees
表中的列名是 emp_department_id
而 departments
表中的列名是 department_id
,那么我们只能使用 ON
子句:
SELECT e.name, d.department_name
FROM employees e
JOIN departments d ON e.emp_department_id = d.department_id;
总结来说,选择使用 USING
还是 ON
取决于具体的使用场景和需求。如果列名相同且只需要基于单一列进行连接,USING
是一个很好的选择。如果需要更复杂的连接条件或列名不匹配,ON
提供了更大的灵活性。