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表 -- -------- ...
随机推荐
- 创建多线程时,为何创建后需要Sleep?
后面的线程用到了前面线程初始的结构,sleep一下只是做到了使前一个线程初始化完成后后一个线程才开始运行.但这样不严格,需要同步机制.在么多个线程都要用的数据结构不要放到子线程内部去初始化,程序启动时 ...
- 五、HashMap的使用 及其源码解析
HashMap的底层实现原理?领接表(数组+链表)hash表数组+链表+红黑树 链表:查找慢 插入 删除快红黑树:查找快 插入 删除慢 HashMap是线程安全的吗?不是线程安全的 在什么情况下 ,是 ...
- MSPBSL_Scripter编译
The BSL Scripter is a PC application that is available for Windows, Linux and Mac OS X. It is a user ...
- cygwin_exception::open_stackdumpfile: Dumping stack trace to HttpServer.exe.stackdump错误
本来,我在Windows下使用Cygwin编译运行c程序,在执行*.exe时报出如题错误,我在Linux环境下使用gcc编译运行,则正常. 所以,当你无法解决上述问题时,换系统吧!
- 定义Java类实现字节流转字符流
package com.buaa.comparable; import java.io.BufferedReader;import java.io.File;import java.io.FileIn ...
- CentOS linux7 设置开机启动服务
常用命令 描述 旧命令 新命令 使服务自动启动 chkconfig --level 3 http on syste ...
- strconv:各种数据类型和字符串之间的相互转换
介绍 strconv包实现了基本数据类型和其对应字符串之间的相互转换.主要有一下常用函数:Atoi,Itoa,Parse系列,Formart系列,Append系列 string和int之间的转换 这一 ...
- Linux常用命令及文件管理
Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示. 目录解释: .代表此层目录: .. 代表父目录:-代表前一个目录:~代表是家目录. (1)ls命令(显示) -a:列出所有文 ...
- 补充:HTML标签和CSS
角标标签: 上角标:sup 下角标:sub <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...
- 用python实现新词发现程序——基于凝固度和自由度
互联网时代,信息产生的数量和传递的速度非常快,语言文字也不断变化更新,新词层出不穷.一个好的新词发现程序对做NLP(自然预言处理)来说是非常重要的. N-Gram加词频 最原始的新词算法莫过于n-gr ...