mysql join 并集_SQL语句的并集UNION 交集JOIN(内连接,外连接)等介绍

SQL语句的并集UNION 交集JOIN(内连接,外连接)等介绍

更新时间:2014年07月06日 00:35:56   投稿:mdxy-dxy

这篇文章主要介绍了SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN) ,需要的朋友可以参考下

1.

a. 并集UNION SELECT column1, column2 FROM table1 UNION SELECT column1, column2 FROM table2

b. 交集JOIN SELECT * FROM table1 AS a JOIN table2 b ON a.name=b.name

c. 差集NOT IN SELECT * FROM table1 WHERE name NOT IN(SELECT name FROM table2)

d. 笛卡尔积 SELECT * FROM table1 CROSS JOIN table2 与 SELECT * FROM table1,table2相同

2.

SQL中的UNION 与UNION ALL的区别是,前者会去除重复的条目,后者会仍旧保留。

a. UNION SQL Statement1 UNION SQL Statement2

b. UNION ALL SQL Statement1 UNION ALL SQL Statement2

3.

SQL中的各种JOIN SQL中的连接可以分为内连接,外连接,以及交叉连接(即是笛卡尔积)

a. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积; 举例 SELECT * FROM table1 CROSS JOIN table2 等同于 SELECT * FROM table1,table2 一般不建议使用该方法,因为如果有WHERE子句的话,往往会先生成两个表行数乘积的行的数据表然后才根据WHERE条件从中选择。 因此,如果两个需要求交际的表太大,将会非常非常慢,不建议使用。

b. 内连接INNER JOIN 如果仅仅使用 SELECT * FROM table1 INNER JOIN table2 没有指定连接条件的话,和交叉连接的结果一样。 但是通常情况下,使用INNER JOIN需要指定连接条件。 -- 等值连接(=号应用于连接条件, 不会去除重复的列)

SELECT * FROM table1 AS a INNER JOIN table2 AS b on a.column=b.column -- 不等连接(>,>=,,!)

例如 SELECT * FROM table1 AS a INNER JOIN table2 AS b on a.column<>b.column -- 自然连接(会去除重复的列)

c. 外连接OUTER JOIN 首先内连接和外连接的不同之处: 内连接如果没有指定连接条件的话,和笛卡尔积的交叉连接结果一样,但是不同于笛卡尔积的地方是,没有笛卡尔积那么复杂要先生成行数乘积的数据表,内连接的效率要高于笛卡尔积的交叉连接。 指定条件的内连接,仅仅返回符合连接条件的条目。外连接则不同,返回的结果不仅包含符合连接条件的行,而且包括左表(左外连接时), 右表(右连接时)或者两边连接(全外连接时)的所有数据行。

1)左外连接LEFT [OUTER] JOIN 显示符合条件的数据行,同时显示左边数据表不符合条件的数据行,右边没有对应的条目显示NULL

例如 SELECT * FROM table1 AS a LEFT [OUTER] JOIN ON a.column=b.column

2)右外连接RIGHT [OUTER] JOIN 显示符合条件的数据行,同时显示右边数据表不符合条件的数据行,左边没有对应的条目显示NULL

例如 SELECT * FROM table1 AS a RIGHT [OUTER] JOIN ON a.column=b.column

3)全外连接显示符合条件的数据行,同时显示左右不符合条件的数据行,相应的左右两边显示NULL

相关文章

1a1b05c64693fbf380aa1344a7812747.png

本文为大家详细介绍下如何获取MSSQL 表结构中字段的备注、主键等信息,感兴趣的朋友可以参考下2013-09-09

4f55910a645b073bc4fc65dc10dc14bd.png

Transact-SQL(又称 T-SQL),是在 Microsoft SQL Server 和 Sybase SQL Server 上的 ANSI SQL 实现,这篇文章主要介绍了Sql Server数据库常用Transact-SQL脚本,需要的朋友可以参考下2019-12-12

0ea3c7666119d5615e582f823fb3fad6.png

对于多级分类常规的处理方法,很多程序员可能是用程序先读取一级分类记录,然后通过一级分类循环读取下面的子分类2012-08-08

4f96a78db829b1556ff16de21e013c7a.png

这篇文章主要介绍了SQL Server中检查字段的值是否为数字的方法,使用ISNUMERIC函数实现,需要的朋友可以参考下2014-06-06

8cc1031babc6aff2319f1c6af8544aa0.png

这篇文章主要介绍了SQL语句性能优化(续),设计到性能优化相关知识,本文介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起学习吧2016-03-03

0c932a99bb7b6f23c937db507070cc7b.png

本文给大家分享一段sql语句实现SqlServer快速检索某个字段在哪些存储过程中,代码非常简单,需要的朋友参考下2017-03-03

cca732bf65a93ed2ec0ac80c638460fe.png

c语言解析http请求表单内容,基于C语言的CGI开发,大家参考使用吧2013-12-12

2d9f31f2af7b675a3d153d2b7f1035a7.png

这篇文章主要介绍了SQL Sever查询语句大全集锦,需要的朋友可以参考下2016-06-06

b452cee8ec5cd9e58ab98eba17281e59.png

mssql中得到当天数据的语句...2007-08-08

f4838ec7e2d4da28e0b57d4e852dadd4.png

经过一段时间的学习,也对数据库有了一些认识,数据库基本是由表,关系,操作组成;对于初学者首先要学的2012-08-08

最新评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值