MySQL关键字—using和on

1. MySQL关键字—using和on

1.1 using关键字的概念

连接查询时如果是同名字段作为连接条件,using可以代替on出现(比on更好),using是针对同名字段(using(id)===on A.id=B.id),using关键字使用后会自动合并对应字段为一个,using可以同时使用多个字段作为条件。

JavaScript中的=====
双等号(==)只比较值是否相等。它本质上是做类型转换。这意味着在比较数值之前,它将变量的类型转换为相互匹配。三等号(===)不执行类型转换。它将验证被比较的变量是否具有相同的值和相同的类型。

使用 USINGON 子句在 SQL 中进行 JOIN 操作时,它们的主要区别在于指定连接条件的方式,下面是两种方法的对比。

2. using和on的区别

2.1 USING 子句

  • USING 子句用于指定两个表之间具有相同名称和数据类型的列作为连接条件。
  • 它是一种简写形式,适用于两个表在指定列上具有完全相同的列名和数据类型。
  • 语法更简洁,避免了重复列名。

优点

  • 代码更简洁,易于阅读和维护。

缺点

  • 限制性较高,只能用于具有相同名称和数据类型的列。
  • 如果需要连接多个列或列名不匹配,不能使用 USING

2.2 ON 子句

  • ON 子句用于指定两个表之间的连接条件,可以是任意的比较表达式。
  • 它不要求列名相同,只要两个表中的列可以进行比较即可。
  • 可以用于更复杂的连接条件,如连接多个列或使用不同的列名。

优点

  • 灵活性高,可以指定任何比较表达式作为连接条件。
  • 适用于列名不同或需要连接多个列的情况。

缺点

  • 语法可能更复杂,特别是在涉及多个列或列名不匹配时。

3. 示例对比

假设我们有两个表 employeesdepartments,它们都有一个共同的列 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');

使用 USINGJOIN 示例:

SELECT e.name, d.department_name
FROM employees e
JOIN departments d USING (department_id);

使用 ONJOIN 示例:

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_iddepartments 表中的列名是 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 提供了更大的灵活性。

  • 18
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值