图解MYSQL JOIN ON,SQL JOIN 详解,数据库sql join语句
2024-10-19 13:31:42
对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚。Coding Horror上有一篇文章(实在不清楚为什么Coding Horror也被墙)通过 文氏图 Venn diagrams 解释了SQL的Join。我觉得清楚易懂,转过来。
假设我们有两张表。
- Table A 是左边的表。
- Table B 是右边的表。
其各有四条记录,其中有两条记录是相同的,如下所示:
id name id name
-- ---- -- ----
1 Pirate 1 Rutabaga
2 Monkey 2 Pirate
3 Ninja 3 Darth Vader
4 Spaghetti 4 Ninja
下面让我们来看看不同的Join会产生什么样的结果。
SELECT * FROM TableA Inner join |
|
SELECT * FROM TableA Full outer join 产生A和B的并集。但是需要注意的是,对于没有匹配的记录,则会以null做为值。 |
|
SELECT * FROM TableA Left outer join 产生表A的完全集,而B表中匹配的则有值,没有匹配的则以null值取代。 |
|
SELECT * FROM TableA 产生在A表中有而在B表中没有的集合。 |
|
SELECT * FROM TableA 产生A表和B表都没有出现的数据集。 |
还需要注册的是我们还有一个是“交差集” cross join, 这种Join没有办法用文式图表示,因为其就是把表A和表B的数据进行一个N*M的组合,即笛卡尔积。表达式如下:
SELECT * FROM TableA
CROSS JOIN TableB
这个笛卡尔乘积会产生 4 x 4 = 16 条记录,一般来说,我们很少用到这个语法。但是我们得小心,如果不是使用嵌套的select语句,一般系统都会产生笛卡尔乘积然再做过滤。这是对于性能来说是非常危险的,尤其是表很大的时候。
(全文完)
最新文章
- iOS比较常用的第三方及实例(不断更新中)
- signalr 配置错误跟踪
- 【XLL 框架库函数】 TempInt/TempInt12
- W3C代码标准规范
- JSONP跨域数据调用
- JavaScript的学习
- 回车键Enter
- 第一章 USB Type C的基本原理
- 重启OpenStack服务步骤
- linux下的权限控制
- form表单上传文件使用multipart请求处理
- Nginx防盗链的3种方法
- .net 和 core2.0 数据库连接字符串
- linux特殊字符及其作用
- angularjs1.x版本,父子组件之间的双向绑定
- 一、VS2017 的创建程序
- kubernetes学习笔记之十二:资源指标API及自定义指标API
- appium架构分析
- Android Studio OkHttpClient使用
- Chapter10(泛型算法)--C++Prime笔记
热门文章
- linux-telnet服务配置
- 线上应用故障排查之一:高CPU占用
- 总结一下.net framework适合装在哪些系统中
- (一)使用Fragment实现QQ的底部按钮
- SQL Server 死锁检查
- 08JS高级 ——“继承”
- Unicode解码、URL编码/解码
- css画图形
- Qt3D教程
- The Struts dispatcher cannot be found. This is usually caused by using Struts tags without the associated filter. 异常