位置: 编程技术 - 正文
联接类型
保留数据行
A left outer join B
all A rows
A right outer join B
all B rows
A full outer join B
all A and B rows
表2 外部联接保留数据行 完整外部联接(full outer join)满足交换律:“A full outer join B” 和 “B full outer join A” 是相等的。 Cross join 交叉联接(cross join)执行两个表的笛卡尔积(就是把表A和表B的数据进行一个N*M的组合)。也就是说,它匹配一个表与另一个表中的每一行;我们不能通过使用ON子句在交叉联接指定谓词,虽然我们可以使用WHERE子句来实现相同的结果,这是交叉联接基本上是作为一个内部联接了。 交叉联接相对于内部联接使用率较低,而且两个大表不应该进行交叉联接,因为这将导致一个非常昂贵的操作和一个非常大的结果集。 具体SQL代码如下: 我们也可以使用内部联接实现和Cross apply相同的查询功能,具体SQL代码如下: 图6 Cross apply查询 Outer apply 在介绍Cross apply和Outer join之后,现在让我们理解Out apply也就不难了,Outer apply使表可以和表值函数(table-valued functions TVF‘s)结果进行join查询,找到匹配值则有值,没有找到匹配值则以NULL表示。 查询执行时间: CPU 时间= 0 毫秒,占用时间= 毫秒。 Inner join查询执行时间: CPU 时间= 0 毫秒,占用时间= 4 毫秒。 图8 执行计划 如图8所示:Cross apply首先执行TVF(table-valued functions),然后对表Studnet进行全表扫描,接着通过遍历sID查找匹配值。 Inner join对表Student和Apply进行全表扫描,然后通过哈希匹配查找匹配的sID值。 通过以上的SQL执行时间和执行计划,我们能不能说Inner join比Cross apply好呢?答案是否定的,如果表的数据量很大,那么Inner join的全表扫描耗费时间和CPU资源就增加了(可通过数据量大的表进行测试)。 虽然大多数采用Cross apply实现的查询,可以通过Inner join实现,但Cross apply可能产生更好的执行计划和更佳的性能,因为它可以在联接执行之前限制集合加入。 Semi-join和Anti-semi-join Semi-join从一个表中返回的行与另一个表中数据行进行不完全联接查询(查找到匹配的数据行就返回,不再继续查找)。 Anti-semi-join从一个表中返回的行与另一个表中数据行进行不完全联接查询,然后返回不匹配的数据。 不同于其他的联接运算,Semi-join和Anti-semi-join没有明确的语法来实现,但Semi-join和Anti-semi-join在SQL Server中有多种应用场合。我们可以使用EXISTS子来实现Semi-join查询,Not EXISTS来实现Anti-semi-join。现在让我们通过具体的例子说明吧! 假设要求我们找出Apply和Student表中sID匹配的学生信息,这和前面的Inner join查询结果将一样,具体SQL代码如下: 我们发现常用的EXISTS子句,原来是通过Left Semi Join实现的,所以说Semi-join在SQL Server中又许多使用场合。 图9 查询结果推荐整理分享SQL Join的一些总结(实例)(sql中的join),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:sql join的用法是什么,sql各种join用法详解,sql语句join on用法,sql中的join,sql语句join on用法,sql各种join用法详解,sql中的join,sql各种join用法详解,内容如对您有帮助,希望把文章链接给更多的朋友!
图 执行计划 现在要求我们找出还没有申请学校的学生信息,这时我们立刻反应可以使用NOT EXISTS子句来实现该查询,具体SQL代码如下: 其实,我们常用的NOT EXISTS子句的实现是通过Anti-semi-join,通过执行计划我们发现在查找匹配sID时,SQL使用 Left Anti Semi Join进行查询。 图 查询结果 图 执行计划 1.1.3 总结 本文介绍了SQL中常用了联接查询方式:Inner join、Outer join、Cross join和Cross apply的使用场合和特性。SQL Transcation的一些总结分享 1.1.1摘要相信大家对于SQLTranscation再熟悉不过,它确保了数据库的数据一致性和安全性,尤其在对数据执行增删时,如果发生异常和错误它就会触发事务
SQL的Join使用图解教程 对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点
SQL中JOIN和UNION区别、用法及示例介绍 1.JOIN和UNION区别join是两张表做交连后里面条件相同的部分记录产生一个记录集,union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集
标签: sql中的join
本文链接地址:https://www.jiuchutong.com/biancheng/348164.html 转载请保留说明!友情链接: 武汉网站建设