sql中的几种连接查询,类型及详解

本文详细介绍了SQL中的四种连接查询:内连接(包括隐式和显示)、外连接(左外、右外、全外)、交叉连接和联合连接。通过实例展示了各种连接查询的用法,对于理解SQL查询和数据操作具有指导意义。
摘要由CSDN通过智能技术生成

一、类型
1、内连接(join或inner join)
有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。(所谓的链接表就是数据库在做查询形成的中间表)。
语句1:隐式的内连接,没有inner join,形成的中间表为两个表的笛卡尔积。

select o.id,o.order_number,c.id,c.name from customers c, orders o wherec.id=o.customer_id;

语句2:显示的内连接,一般称为内连接,有inner join,形成的中间表为两个表经过on条件过滤后的笛卡尔积。

select o.id,o.order_number,c.id,c.name from customers c inner join orders o onc.id=o.customer_id;

2、外连接(outer join)
外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。左表就是在“(left outer join)”关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,outer 关键字是可省略的
外连接分三类:
①左外连接(left join或left outer join)
②右外连接(right join或right outer join)
③全外连接(full join或full outer join)

1>共同点:
都返回符合连接条件和查询条件(即:内连接)的数据行
2>不同点:
左外连接还返回左表中不符合连接条件单符合查询条件的数据行。
右外连接还返回右表中不符合连接条件单符合查询条件的数据行。
全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 union 右外”。
例子:

语句5:左外连接(left outer join)

select o.id,o.order_number,o.customer_id,c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值