连接、关联、JOIN、APPLY(SQL Server)
|
连接方式 |
连接类型 |
个人总结 |
阐述(生成两个集合的约束笛卡儿积) |
|
INNER JOIN |
内连接 |
关联相同的(用于查找关联的信息) |
FROM C AS c INNER JOIN D AS d ON c.xx = d.xx |
|
LEFT JOIN |
左连接 |
左面全保留(可以用来查找左面多余的,右面为NULL) |
FROM C AS c LEFT OUTER JOIN D AS d ON c.xx = d.xx |
|
RIGHT JOIN |
右连接 |
右面全保留(可以用来查找右面多余的,左面为NULL) |
FROM C AS c RIGHT OUTER JOIN D AS d ON c.xx = d.xx |
|
FULL JOIN |
完全连接 |
显示左右关联上和左右关联不上的,关联不上为NULL |
FROM C AS c FULL OUTER JOIN D AS d ON c.xx = d.xx |
|
CROSS JOIN |
交叉连接 |
左右互相1对全部连接 |
FROM C AS c CROSS JOIN D as d |
|
|
|
延伸学习 |
关于EXCEPT和INTERSECT的用法 |
|
EXCEPT |
也是去重的, 但是它在去掉两个或多个集合中重复数据之后, 只会保留第一个结果集中的数据 |
|
INTERSECT |
就是查询两个结果集的并集, 利用上面的数据 |
|
学习地址 |
物理连接 |
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)的更多相关文章
- INNER JOIN与LEFT JOIN在SQL Server的性能
我创建了INNER JOIN 9桌,反正需要很长的(超过五分钟).所以,我的民歌改变INNER JOIN来LEFT JOIN LEFT JOIN的性能较好,在首次尽管我所知道的.之后我变了,查询的速度 ...
- 问题:sqlserver 跨服务器连接;结果:Sql Server 跨服务器连接
Sql Server 跨服务器连接 用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset ...
- SQL Server 无法连接到服务器。SQL Server 复制需要有实际的服务器名称才能连接到服务器。请指定实际的服务器名称。
异常处理汇总-数据库系列 http://www.cnblogs.com/dunitian/p/4522990.html SQL性能优化汇总篇:http://www.cnblogs.com/dunit ...
- 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 ...
- 使用 cmd连接 Oracle,MySql,SQL Server 数据库
1. Oracle cmd连接数据库 语法: sqlplus 用户/口令(密码)@服务器IP/数据库实例名(SID) 1.1 方式一 数据库服务在本机上IP可以用localhost替换 sqlplus ...
- FineReport9.0定义数据连接(创建与SQL Server 2016数据库的连接)
1.下载并安装好FineReport9.0和SQL Server 2016 2.开始——>所有应用——>Microsoft SQL Server 2016——>SQL Server ...
- 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 ...
- 如何远程连接非默认端口SQL Server
SQL Server Management Studio建立远程SQL连接 连接的时候写: 127.0.0.1,49685\sqlexpress 记得使用逗号,不是冒号
- .net core连接Liunx上MS SQL Server
场景 由于业务要求,需要对甲方的一个在SQL Server上的财务表进行插入操作.研究了半天,因为一个小问题折腾了很久. 过程 .net core端: 1. 利用EF,就需要的导入相关的Nuget包, ...
- sql连接错误(Microsoft SQL Server,错误:2)
昨天用SQL语句建表的时候写了一段代码,对于代码的逻辑和内容我不太肯定对不正确.反正是毫不犹豫的让它运行了,过程中出现好几个错误,当时没有太在意,想着大不了出错了再重写一个.结果--玩坏了,从昨天到如 ...
随机推荐
- 扩展PHP内置的异常处理类
在try代码块中,需要使用throw语句抛出一个异常对象,才能跳到转到catch代码块中执行,并在catch代码块中捕获并使用这个异常类的对象.虽然在PHP中提供的内置异常处理类Exception,已 ...
- display 属性
这里向大家描述一下HTML DOM display属性的定义和用法,HTML DOM display属性主要用来设置元素如何显示,比如当此属性值为none时,表示此元素不会被显示,而block则表示此 ...
- Android模拟器genymotion安装与eclipse 插件安装
推荐一款Android模拟器"Genymotion",有点速度快,占用资源少,可整合eclipse.闲话少谈,看安装步骤. 1.下载地址:https://www.genymotio ...
- 实验三:gdb跟踪调试内核从start_kernel到init进程启动
原创作品转载请注明出处<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 如果我写的不好或者有误的地方请留言 ...
- Scut:GameWebSocketHost 解析
想使用 Scut 做的是一个短连接项目,所以先直接看 GameWebSocketHost 了. 先来看下 GameWebSocketHost 的成员: protected bool EnableHtt ...
- poj 3020Antenna Placement
http://poj.org/problem?id=3020 #include<cstdio> #include<cstring> #include<algorithm& ...
- 【HDOJ】5155 Harry And Magic Box
DP.dp[i][j]可以表示i行j列满足要求的组合个数,考虑dp[i-1][k]满足条件,那么第i行的那k列可以为任意排列(2^k),其余的j-k列必须全为1,因此dp[i][j] += dp[i- ...
- POJ 3268 Silver Cow Party ( Dijkstra )
题目大意: 有N个农场每个农场要有一头牛去参加一个聚会,连接每个农场有m条路, 聚会地点是X,并且路是单向的.要求的是所有牛赶到聚会地点并且回到自己原先的农场所需要的最短时间. 题目分析: 其实就是以 ...
- 舶来品P2P理财 能否成为“好声音”式好生意? 转
华股财经 2012年11月29日 10:20:02 来源:互联网 字号:T|T 文/本刊记者 王奇 有数据显示,目前国内已有2000余家P2P公司,2007年至2011年上半年,其整体融资规模由2 ...
- [Design Pattern] Facde Pattern 简单案例
Facade Pattern, 即外观模式,用于隐藏复杂的系统内部逻辑,提供简洁的接口给客户端调用,属于结构类的设计模式.我会将其名字理解为,门户模式. 下面是 Facade Pattern 的一个简 ...
