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表 -- -------- ...
随机推荐
- K最近邻算法项目实战
这里我们用酒的分类来进行实战练习 下面来代码 1.把酒的数据集载入到项目中 from sklearn.datasets import load_wine #从sklearn的datasets模块载入数 ...
- cnn健康增胖和调理好身体
吃不胖,其实大部分情况是消化系统不好,大部分食物都没有被身体吸收就被排掉了. 1,改善肠胃消化功能: 每天早上一杯全脂鲜牛奶(或者羊奶), 每天晚上一杯酸奶 ps:白天和鲜牛奶可以激发肠胃的消化能力. ...
- kong网关命令(一)
上次在虚拟机里安装kong网关后,因为版本(1.4)太高,目前Kong Dashboard无法支持, 后续发现Git上有个开源工具Kong admin ui,下载源码并部署到NGINX. 但是发现使用 ...
- spring将service添加事务管理,在applicationContext.xml文件中的设置
在applicationContext.xml文件中的设置为: <beans> <bean id="sessionFactory" class="org ...
- 正则限制input负数输入
//直接在input标签内加入下面两个事件处理程序即可 onkeyup="this.value=this.value.replace(/\D|^0/g,'')" onafterpa ...
- redis cluster异地数据迁移,扩容,缩容
由于项目的服务器分布在重庆,上海,台北,休斯顿,所以需要做异地容灾需求.当前的mysql,redis cluster,elastic search都在重庆的如果重庆停电了,整个应用都不能用了. 现在考 ...
- javascript新特性
让我们看看javascript中的一些新特性.本文将介绍它们的语法和相关链接,以帮助读者及时了解它们的进展.我们将通过编写一个小测试项目来演示如何快速使用这些新功能! 关于提案 提案分为五个阶段.有关 ...
- Twitter Bootstrap:前端框架利器
Bootstrap 的文件结构 读者可以直接从 GitHub 下载到 Bootstrap 源码,本地解压后可以看到这样的目录结构:docs.img.jquery-ui- bootstrap.js 和 ...
- java - day010 - 基本类型包装,自动装箱和拆箱,日期,集合
基本类型的包装类 byte Byte short Short int Integer long Long float Float double Double char Character boolea ...
- 15_sqoop数据导出
1.Sqoop的数据导出 将数据从HDFS导出到RDBMS数据库,导出前,目标表必须存在于目标数据库中 默认操作是将文件中的数据使用INSERT语句插入到表中 更新模式下,是生成UPDATE语句更新表 ...