连接方式

连接类型

个人总结

阐述(生成两个集合的约束笛卡儿积)

INNER    JOIN

内连接

关联相同的(用于查找关联的信息)

FROM C AS c INNER JOIN D AS d ON c.xx = d.xx
前面的查询表达式将 ON 条件为 true 的每一个左侧集合元素与其右侧集合的配对元素组合起来。
如果未指定 ON 条件,则 INNER JOIN 退化为 CROSS JOIN。

LEFT     JOIN

左连接

左面全保留(可以用来查找左面多余的,右面为NULL)

FROM C AS c LEFT OUTER JOIN D AS d ON c.xx = d.xx
前面的查询表达式将 ON 条件为 true 的每一个左侧集合元素与其右侧集合的配对元素组合起来。
如果 ON 条件为 false,表达式仍处理与右侧元素(值为 null)配对的单个左侧元素实例。

RIGHT   JOIN

右连接

右面全保留(可以用来查找右面多余的,左面为NULL)

FROM C AS c RIGHT OUTER JOIN D AS d ON c.xx = d.xx
前面的查询表达式将 ON 条件为 true 的每一个右侧集合元素与其左侧集合的配对元素组合起来。
如果 ON 条件为 false,表达式仍处理与左侧元素(值为 null)配对的单个左侧元素实例。

FULL     JOIN

完全连接

显示左右关联上和左右关联不上的,关联不上为NULL

FROM C AS c FULL OUTER JOIN D AS d ON c.xx = d.xx
前面的查询表达式将 ON 条件为 true 的每一个左侧集合元素与其右侧集合的配对元素组合起来。
如果 ON 条件为 false,表达式仍处理与右侧元素(值为 null)配对的一个左侧元素实例。
此外,它还处理与左侧元素(值为 null)配对的一个左侧元素实例。

CROSS  JOIN

交叉连接

左右互相1对全部连接

FROM C AS c CROSS JOIN D as d
指定两个表的叉积,返回相同的行。

延伸学习

关于EXCEPT和INTERSECT的用法

EXCEPT

也是去重的, 但是它在去掉两个或多个集合中重复数据之后, 只会保留第一个结果集中的数据
查询上面有下面没有的
SELECT * FROM [dbo].[JOIN1]
EXCEPT
SELECT * FROM [dbo].[JOIN2]

INTERSECT

就是查询两个结果集的并集, 利用上面的数据
查询两个结果集中相同的
SELECT * FROM [dbo].[JOIN1]
INTERSECT
SELECT * FROM [dbo].[JOIN2]

学习地址

http://blog.csdn.net/tjvictor/article/details/5346024

物理连接

Nested Loops Join(嵌套循环连接)

Merge Join(合并连接)

Hash Join(哈希连接)

最适合于 相对较小的两个数据集,
inner table在做Join的字段上有一个索引
输入数据集大小中等或较大,
且在Join字段上有索引帮助排序,
或者语句要求返回一个排好序的结果集
输入数据集较大。
尤其适合于Data warehouse 环境下的那些复杂的查询语句
并发性 能够支持大量的并发用户同时运行 有索引支持的Many-to-one的join并发性较好,
Many-To-Many的就差了
最好同时只有少数用户在同时运行
Join时要否两个字段相等 不要 要(除非是full outer join)
要否使用内存资源 不使用 不使用(如果要为Merge Join做排序,可能要使用) 使用
要否使用tempdb 不使用 many-to-many join要使用 使用
输入数据集要否排序 不要 不要
希望输入数据集排序否 希望outer input是排序的 是的 不要
学习地址 http://www.cnblogs.com/CareySon/archive/2013/01/09/2853094.html
 
APPLY 使用 APPLY 运算符可以为实现查询操作的外部表表达式返回的每个行调用表值函数。表值函数作为右输入,外部表表达式作为左输入。通过对右输入求值来获得左输入每一行的计算结果,生成的行被组合起来作为最终输出。APPLY 运算符生成的列的列表是左输入中的列集,后跟右输入返回的列的列表。
学习地址 https://technet.microsoft.com/zh-cn/library/ms175156(v=sql.105).aspx
  http://blog.csdn.net/ylqmf/article/details/5316694
  http://www.cnblogs.com/yukaizhao/archive/2008/04/30/cross_apply.html

连接、关联、JOIN、APPLY(SQL Server)的更多相关文章

  1. INNER JOIN与LEFT JOIN在SQL Server的性能

    我创建了INNER JOIN 9桌,反正需要很长的(超过五分钟).所以,我的民歌改变INNER JOIN来LEFT JOIN LEFT JOIN的性能较好,在首次尽管我所知道的.之后我变了,查询的速度 ...

  2. 问题:sqlserver 跨服务器连接;结果:Sql Server 跨服务器连接

    Sql Server 跨服务器连接 用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset ...

  3. SQL Server 无法连接到服务器。SQL Server 复制需要有实际的服务器名称才能连接到服务器。请指定实际的服务器名称。

    异常处理汇总-数据库系列  http://www.cnblogs.com/dunitian/p/4522990.html SQL性能优化汇总篇:http://www.cnblogs.com/dunit ...

  4. com.microsoft.sqlserver.jdbc.SQLServerException: 通过端口 1433 连接到主机 127.0.0.1 的 TCP/IP 连接失败。错误:“Connection refused: connect。请验证连接属性。确保 SQL Server 的实例正在主机上运行,且在此端口接受 TCP/IP 连接,还要确保防火墙没有阻止到此端口的 TCP 连接。”

    检查SQL Server Configuration Manager 确定实例名为"SKYSQLEXPRESS"下的TCP/IP已经开启了: sql2014配置(系统为Window ...

  5. 使用 cmd连接 Oracle,MySql,SQL Server 数据库

    1. Oracle cmd连接数据库 语法: sqlplus 用户/口令(密码)@服务器IP/数据库实例名(SID) 1.1 方式一 数据库服务在本机上IP可以用localhost替换 sqlplus ...

  6. FineReport9.0定义数据连接(创建与SQL Server 2016数据库的连接)

    1.下载并安装好FineReport9.0和SQL Server 2016 2.开始——>所有应用——>Microsoft SQL Server 2016——>SQL Server ...

  7. How to Delete using INNER JOIN with SQL Server?

    https://stackoverflow.com/questions/16481379/how-to-delete-using-inner-join-with-sql-server You need ...

  8. 如何远程连接非默认端口SQL Server

    SQL Server Management Studio建立远程SQL连接  连接的时候写: 127.0.0.1,49685\sqlexpress 记得使用逗号,不是冒号

  9. .net core连接Liunx上MS SQL Server

    场景 由于业务要求,需要对甲方的一个在SQL Server上的财务表进行插入操作.研究了半天,因为一个小问题折腾了很久. 过程 .net core端: 1. 利用EF,就需要的导入相关的Nuget包, ...

  10. sql连接错误(Microsoft SQL Server,错误:2)

    昨天用SQL语句建表的时候写了一段代码,对于代码的逻辑和内容我不太肯定对不正确.反正是毫不犹豫的让它运行了,过程中出现好几个错误,当时没有太在意,想着大不了出错了再重写一个.结果--玩坏了,从昨天到如 ...

随机推荐

  1. Scrapy使用以及Xpath的一些坑, 再入剁手

    scrapy爬虫: https:www.scrapy.org 本篇博客依托的项目: https://github.com/viciousstar/BitcointalkSpider/ 一. Scrap ...

  2. php in_array比较原理和类型比较问题

    in_array 是PHP 的检查数组中是否存在某个值 的函数,里面有三个参数 bool in_array ( mixed $needle , array $haystack [, bool $str ...

  3. mongose排序查询

    Kc.find({bjid:req.params.bjid}).sort({'_id':1}).exec(function(err,kcs){ if(err){ res.json({no:0,msg: ...

  4. asp.net请求流程

    http://developer.51cto.com/art/200902/109441.htm http://www.cnblogs.com/couhujia/archive/2010/04/21/ ...

  5. bing---iis how to process http request

    http://msdn.microsoft.com/en-us/library/ms524901(v=vs.90).aspx http://msdn.microsoft.com/en-us/magaz ...

  6. COJ 0990 WZJ的数据结构(负十)

    WZJ的数据结构(负十) 难度级别:D: 运行时间限制:5000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 给你一个N个节点的有根树,从1到N编号,根节点为1并给 ...

  7. 主席树套树状数组 动态区间第k小

    先打上代码以后更新解释 #include <cstdio> #include <iostream> #include <algorithm> #include &l ...

  8. CentOS 6.4 安装 Fcitx4.0

    一.首先安装中文支持: su root yum install "@Chinese Support" exit yum remove ibus 注销再登陆 二.安装fcitx 下载 ...

  9. 【用PS3手柄在安卓设备上玩游戏系列】谈安卓游戏对手柄的支持

    不同的游戏对于手柄的支持程度是不一样的,对应所需要进行的手柄设置也不尽相同.我没有这样的时间和精力,针对每一款游戏去写博客,但找出不同游戏中的共同点,针对同一类的游戏去写博客,应该是可行的.我把安卓上 ...

  10. [Java] 模板引擎 Velocity 随笔

    Velocity 是一个基于 Java 的模板引擎. 本博文演示 Velocity 的 HelloWord 以及分支条件. HelloWord.vm,模板文件. templateDemo.java, ...