SQL连接查询基础知识点
什么是连接
连接(join)查询是基于多个表中的关联字段将数据行拼接到一起,可以同时返回多个表中的数据。
下面以两个表为例子,举例说明一下不同的连接。
SELECT * FROM products
| id | name | price | detail | vender_id |
|---|---|---|---|---|
| 1 | 苹果 | 3.5 | 花牛苹果 | 1 |
| 2 | 蜜桃 | 3.5 | 秦安蜜桃 | 1 |
| 3 | 香蕉 | 2.5 | 海南香蕉 | 2 |
| 4 | 椰子 | 4.5 | 海南椰子 | 2 |
| 5 | 火龙果 | 3.5 | 红心火龙果 | NULL |
| 6 | 柚子 | 红柚 | 3.5 | NULL |
SELECT * FROM vendors
| id | name | phone | location |
|---|---|---|---|
| 1 | 秦安水果王 | 666999 | 秦安县 |
| 2 | 海南水果 | 666888 | 海南岛 |
| 3 | 泰国进口水果 | 123456 | 泰国 |
| 4 | 菲律宾进口水果 | 321654 | 菲律宾 |
SQL连接类型
内连接(inner join)
用于返回两个表中满足连接条件的数据行。
SELECT
p.id, p.name, p.vender_id, v.id, v.name
FROM
products AS p
JOIN
vendors AS v ON p.vender_id = v.id
| id | name | vender_id | id | name |
|---|---|---|---|---|
| 1 | 苹果 | 1 | 1 | 秦安水果王 |
| 2 | 蜜桃 | 1 | 1 | 秦安水果王 |
| 3 | 香蕉 | 2 | 2 | 海南水果 |
| 4 | 椰子 | 2 | 2 | 海南水果 |
左外连接(left outer join)
返回左表中所有的数据行,对于右表中的数据,如果没有匹配的值,返回空值。
SELECT
p.id, p.name, p.vender_id, v.id, v.name
FROM
products AS p
LEFT JOIN
vendors AS v ON p.vender_id = v.id
| id | name | vender_id | id | name |
|---|---|---|---|---|
| 1 | 苹果 | 1 | 1 | 秦安水果王 |
| 2 | 蜜桃 | 1 | 1 | 秦安水果王 |
| 3 | 香蕉 | 2 | 2 | 海南水果 |
| 4 | 椰子 | 2 | 2 | 海南水果 |
| 5 | 火龙果 | NULL | NULL | NULL |
| 6 | 柚子 | NULL | NULL | NULL |
右外连接(right outer join)
返回右表中所有的数据行,对于左表中的数据,如果没有匹配的值,返回空值。
SELECT
p.id, p.name, p.vender_id, v.id, v.name
FROM
products AS p
RIGHT JOIN
vendors AS v ON p.vender_id = v.id
| id | name | vender_id | id | name |
|---|---|---|---|---|
| 1 | 苹果 | 1 | 1 | 秦安水果王 |
| 2 | 蜜桃 | 1 | 1 | 秦安水果王 |
| 3 | 香蕉 | 2 | 2 | 海南水果 |
| 4 | 椰子 | 2 | 2 | 海南水果 |
| NULL | NULL | NULL | 3 | 泰国进口水果 |
| NULL | NULL | NULL | 4 | 菲律宾进口水果 |
全外连接(full outer join)
等价于左外连接加上右外连接,返回左表和右表中所有的数据行,MySQL 不支持全外连接。
交叉连接(cross join)
交叉连接,也称为笛卡尔积,两个表的笛卡尔积相当于一个表的所有行和另一个表的所有行两两组合,结果的数量为两个表的行数相乘。
自连接(self join)
是指连接操作符的两边都是同一个表,没什么特别的,可以认为是把一个表复制一份后,和它原来的表进行各种连接操作。
SQL连接查询基础知识点的更多相关文章
- sql连接查询中的分类
sql连接查询中的分类 1.内连接(结果不保留表中未对应的数据) 1.1等值连接:关联条件的运算符是用等号来连接的. 1.2不等值连接:连接条件是出等号之外的操作符 1.3自然连接:特殊的等值连接,在 ...
- sql连接查询(inner join、full join、left join、 right join)
sql连接查询(inner join.full join.left join. right join) 一.内连接(inner join) 首先我这有两张表 1.顾客信息表customer 2.消费订 ...
- SQLServer SQL连接查询深度探险(摘录
SQL连接查询深度探险[摘录] 测试环境: Windows XP Profession MySQL 5.0.45 Oracle 9i DB2 UDB 9.1 测试的SQL脚本如下:此脚本适合MySQL ...
- 【SQL】- 基础知识梳理(三) - SQL连接查询
一.引言 有时为了得到一张报表的完整数据,需要从两个或更多的表中获取结果,这时就用到了"连接查询". 二.连接查询 连接查询的定义: 数据库中的表通过键将彼此联系起来,从而获取这些 ...
- sql连接查询中on筛选与where筛选的区别
sql查询这个东西, 要说它简单, 可以很简单, 通常情况下只需使用增删查改配合编程语言的逻辑表达能力,就能实现所有功能. 但是增删查改并不能代表sql语句的所有, 完整的sql功能会另人望而生畏. ...
- SQL高级查询基础
1.UNION,EXCEPT,INTERSECT运算符 A,UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表. ...
- sql 连接查询
什么是连接查询呢 概念:根据两个表或多个表的列之间的关系,从这些表中查询数据. 目的:实现多个表查询操作. 分类 首先划分一下,连接分为三种:内连接.外连接.交叉连接 内连接(INNER JOIN): ...
- SQL连接查询、变量、运算符、分支、循环语句
连接查询:通过连接运算符可以实现多个表查询.连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志. 常用的两个链接运算符: 1.join on 2.union 在关系数据库 ...
- MySQL学习(四) SQL连接查询
更多情况下,我们查询的数据来源于多张表,所有有必要了解一下MySQL中的连接查询. SQL中将连接查询分成四类:交叉连接,内连接,外连接和自然连接. 数据准备 student表 -- -------- ...
随机推荐
- QTabWidget标签实现双击关闭(转)
重载了QTabWidget(由于tabBar()是protected),这样就可以获取到标签了. 1 class Tab : public QTabWidget 2 { 3 Q_OBJECT 4 pu ...
- 恺撒密码 I
恺撒密码 I ...
- JavaScript知识点:分支结构(if、switch)+算法例题
if-else分支 1.if条件应该是boolean类型的值或表达式 2.如果条件不是Boolean,会进行自动转换 以下几种情况会默认转换为 false: if(0).if(0.0) if(NaN) ...
- Flutter-现有iOS工程引入Flutter
前言 Flutter 是一个很有潜力的框架,但是目前使用Flutter的APP并不算很多,相关资料并不丰富,介绍现有工程引入Flutter的相关文章也比较少.项目从零开始,引入Flutter操作比较简 ...
- C++ 函数重载二义性
说起函数重载,我不由得想起了C++的“多态”特性.多态又分为静态(编译时)多态和动态(运行时)多态,静态多态即为函数重载,动态多态则是虚函数机制.虚函数水较深,先不讨论,今天我们来看一下函数重载.作用 ...
- h5常见
Meta基础知识: H5页面窗口自动调整到设备宽度,并禁止用户缩放页面//一.HTML页面结构<meta name="viewport" content="widt ...
- KVM之virsh管理Storage pool
创建基于文件夹的存储池 基于文件夹的存储池: [root@ubuntu01 ~]# mkdir /data/vm_pool [root@ubuntu01 ~]# virsh pool-create-a ...
- eclipse导入项目后出现红色叉号的解决方案
对于一名程序员来说,我导入的项目在项目的名称上无端加了一个红色的叉号,虽然这个不友好的符号,对于我整个的项目运行没有任何影响,但是总让我觉得不舒服,大大的叉号写在我的项目的脑袋上,我心里能舒服吗?于是 ...
- 解决Centos /boot过小无法更新内核
Centos7默认安装时,/boot目录设置只有150M左右,这样编译几个版本的内核/boot空间就不够用了.报错大致如下: Disk Requirements: At least 3MB more ...
- 深度解析Graph Embedding
Graph Embedding是推荐系统.计算广告领域最近非常流行的做法,是从word2vec等一路发展而来的Embedding技术的最新延伸:并且已经有很多大厂将Graph Embedding应用于 ...