MySQL【内连接与外连接】

1.内连接:inner join on【重点】

inner join on:只返回两个表中连接条件相匹配的行。

select 表1.字段1 ,表2.字段2,......
from 表1 inner join 表2
on 表1.字段A = 表2.字段A;

#查看emp表与test表中名称相同的人的工资:
select emp.name, emp.salary as "emp表工资",test.salary  as "test表工资"
from emp inner join test
on emp.name = test.name;

第二种方式:

select 表1.字段1 ,表2.字段2,......
from 表1,表2 
where 表1.字段A = 表2.字段A;

#查看emp表与test表中工资相同的人的名称:
select emp.id,emp.name as "emp表",emp.salary,test.name  as "test表"
from emp,test 
where emp.salary = test.salary;

2.外连接:outer join on【重点】

在做多张表查询时,所需要的数据,除了满足关联条件的数据外,还有不满足关联条件的数据。此时需要使用外连接,外连接分为三种:

左外连接:表A left [outer] join 表B on 关联条件,表A是主表,表B是从表

右外连接:表A right [outer] join 表B on 关联条件,表B是主表,表A是从表

全外连接:表A full [outer] join 表B on 关联条件,两张表的数据不管满不满足条件,都做显示。

左外连接(left join on):

左外连接:返回左表(from子句中的表)的所有行,即使右表中没有匹配的行,没有则返回NULL。

两个表在来连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行

select 表1.字段1 ,表2.字段2,......
from 表1 left join 表2
on 表1.字段A = 表2.字段A;

select emp.id ,emp.name, test.name
from emp left join test
on emp.name = test.name;

右外连接(right join on):

右外连接:在功能上与左外连接相反,它返回右表中的所有行,即使左表中没有匹配的行,没有则返回NULL。在MySQL中,右外连接的使用不如左外连接常见。

两个表在来连接过程中除了返回满足连接条件的行以外还返回右表中不满足条件的行

select 表1.字段1 ,表2.字段2,......
from 表1 right join 表2
on 表1.字段A = 表2.字段A;

select emp.id ,emp.name, test.name
from emp right join test
on emp.name = test.name;

满外连接(full outer join):

满外连接:返回两个表中所有行,无论它们是否匹配。如果某一边没有匹配,相应的结果将为NULL。

注意:MySQL不支持全外连接,但你可以通过结合左外连接和右外连接来模拟全外连接。

合并查询结果利用union关键字,可以给出多条SELECT语句,并将它们的结果组合成单个结果集。合并时,两个表对应的列数和数据类型必须相同,并且相互对应。各个SELECT语句之间使用UNION或UNION ALL关键字分隔。

1.UNION 操作符:返回两个查询的结果集的并集,去除重复记录【不建议使用】

select a.*, b.*    --a,b为别名
from table1 a left join table2 b 
on a.column_name = b.column_name
union all
select a.*, b.*
from table1 a right join table2 b 
on a.column_name = b.column_name

#匹配两表中名字相同的字段
select emp.*, test.*
from emp left join test 
on emp.name = test.name
union all
select test.*, emp.*
from empright join test 
on emp.name = test.name
where emp.name is NULL;

2.UNION ALL操作符:返回两个查询的结果集的并集。对于两个结果集的重复部分,不去重。

注意:执行 union all 语句时所需要的资源比UNION语句少。如果明确知道合并数据后的结果数据不存在重复数据,或者不需要去除重复的数据,则尽量使用UNION ALL语句,以提高数据查询的效率。

## 查询时,两条语句的字段要对应上,from和join表要对应一致
#左中图+右上图:
select t1.employee_id,t1.last_name,t2.department_name
from employees t1 left join departments t2
on t1.department_id = t2.department_id
where t2.department_id IS NULL
UNION ALL                     #没有去重操作,效率高
select t1.employee_id,t1.last_name,t2.department_name
from employees t1 right join departments t2
on t1.department_id = t2.department_id;

#左上图+右中图:
SELECT t1.last_name,t1.salary,t2.department_name,t2.department_id
FROM employees t1 left JOIN departments t2
ON t1.department_id = t2.department_id
UNION ALL 
SELECT t1.last_name,t1.salary,t2.department_name,t2.department_id 
FROM employees t1 right JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t1.department_id IS NULL; 

#右下图:查询没有部门的员工信息以及所有员工的部门信息
SELECT t1.employee_id,t1.last_name,t2.department_name
FROM employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t2.department_id IS NULL
UNION ALL
SELECT t1.employee_id,t1.last_name,t2.department_name
FROM employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t1.department_id IS NULL;

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中的连接是用于将多个表中的数据进行关联查询的操作。连接分为内连接外连接两种类型。 1. 内连接(INNER JOIN):内连接返回两个表中满足连接条件的行,即只返回两个表中有匹配关系的数据。内连接使用JOIN关键字来进行连接操作。例如,假设有两个表A和B,通过某个共同的字段进行连接,可以使用以下语法进行内连接: ```sql SELECT * FROM tableA INNER JOIN tableB ON tableA.column = tableB.column; ``` 2. 外连接(OUTER JOIN):外连接返回两个表中满足连接条件的行,同时还返回一个表中没有匹配关系的行。外连接分为左外连接、右外连接和全外连接三种类型。 - 左外连接(LEFT JOIN):左外连接返回左表中所有的行,以及右表中满足连接条件的行。如果右表中没有匹配的行,则对应的字段值为NULL。语法如下: ```sql SELECT * FROM tableA LEFT JOIN tableB ON tableA.column = tableB.column; ``` - 右外连接(RIGHT JOIN):右外连接返回右表中所有的行,以及左表中满足连接条件的行。如果左表中没有匹配的行,则对应的字段值为NULL。语法如下: ```sql SELECT * FROM tableA RIGHT JOIN tableB ON tableA.column = tableB.column; ``` - 全外连接(FULL JOIN):全外连接返回两个表中所有的行,如果某个表中没有匹配的行,则对应的字段值为NULL。MySQL中没有直接支持全外连接的语法,但可以通过左外连接和右外连接的组合来实现。 需要注意的是,连接操作需要使用ON关键字指定连接条件,即连接两个表的字段。在使用连接操作时,需要确保连接条件是正确的,并且表中有适当的索引来提高查询性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值