sql Join用法
来源:互联网 发布:java开发mes系统 编辑:程序博客网 时间:2024/04/27 14:10
假设我们有两张表,Table A是左边的表,Table B是右边的表。
其各有四条记录,其中有两条记录是相同的,如下所示:
id name id name-- ---- -- ----1 Pirate 1 Rutabaga2 Monkey 2 Pirate3 Ninja 3 Darth Vader4 Spaghetti 4 Ninja
下面让我们来看看不同的Join会产生什么样的结果。
SELECT * FROM TableA INNER JOIN TableBON TableA.name = TableB.nameid name id name-- ---- -- ----1 Pirate 2 Pirate3 Ninja 4 Ninja
Inner join
产生的结果集中,是A和B的交集。
SELECT * FROM TableA FULL OUTER JOIN TableBON TableA.name = TableB.nameid name id name-- ---- -- ----1 Pirate 2 Pirate2 Monkey null null3 Ninja 4 Ninja4 Spaghetti null nullnullnull1 Rutabaganullnull3 Darth Vader
Full outer join 产生A和B的并集。但是需要注意的是,对于没有匹配的记录,则会以null做为值。
SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.nameid name id name-- ---- -- ----1 Pirate 2 Pirate2 Monkeynullnull3 Ninja 4 Ninja4 Spaghettinullnull
Left outer join 产生表A的完全集,而B表中匹配的则有值,没有匹配的则以null值取代。
SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name WHERE TableB.id IS nullid name id name-- ---- -- ----2 Monkeynullnull4 Spaghettinullnull
产生在A表中有而在B表中没有的集合。
SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name WHERE TableA.id IS null OR TableB.id IS nullid name id name-- ---- -- ----2 Monkeynullnull4 Spaghettinullnullnullnull1 Rutabaganullnull3 Darth Vader
产生A表和B表都没有出现的数据集。
还需要注册的是我们还有一个是"交差集" cross join, 这种Join没有办法用文式图表示,因为其就是把表A和表B的数据进行一个N*M的组合,即笛卡尔积。表达式如下:
SELECT * FROM TableACROSS JOIN TableB
这个笛卡尔乘积会产生 4 x 4 = 16 条记录,一般来说,我们很少用到这个语法。但是我们得小心,如果不是使用嵌套的select语句,一般系统都会产生笛卡尔乘积然再做过滤。这是对于性能来说是非常危险的,尤其是表很大的时候。
0 0
- SQL JOIN 的用法
- sql join用法
- SQL JOIN 的用法
- sql join用法
- *SQL JOIN 的用法
- SQL join完全用法
- sql join 完全用法
- SQL Join的用法
- 图解SQL Join用法
- Sql Join各种用法
- SQL学习----JOIN 用法
- sql left join 用法
- SQL JOIN用法
- SQL的join用法
- SQL JOIN 的用法
- SQL JOIN 的用法
- SQL JOIN 的用法
- SQL Join 用法详解
- Very deep convolutional networks for larage-scale image recognition
- .hpp文件和.h文件的区别
- Hive分析窗口函数(五) GROUPING SETS,GROUPING__ID,CUBE,ROLLUP
- 字符类Character(参考java语言程序设计)
- Linux文件管理--通配符
- sql Join用法
- 如何设置UNIX/Linux中新创建目录或文件的默认权限
- SRM 510 DIV2 1000 TheLuckyBasesDivTwo
- Linux 下 SVN 创建操作流程(客户端mac osx)
- py3环境bytes转换unicode注意
- Day5:Meeting in Laboratory
- java设计模式——装饰者模式Decorator
- android 画图的几个方法
- 对于FILE,LINE,func这样的宏