从品牌网站建设到网络营销策划,从策略到执行的一站式服务
SQL Server中如何使用Apply关键字,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
创新互联-专业网站定制、快速模板网站建设、高性价比吉安网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式吉安网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖吉安地区。费用合理售后完善,十载实体公司更值得信赖。
1、概念介绍
APPLy关键字是SQLServer版本中开始提供的一个系统关键字。
APPLY的功能同联接很类似,APPLY运算分左右两个部分,
APPLY的右表达式:左表达式的每一行都和右表达式进行一次计算,即右表达式需要根据左表达式提供的值进行相关计算来获取相关结果,然后返回给客户端。
APPLY的右表达式:是一个子查询或表值函数。
APPLY:先进行左表达式的数据获取,然后根据左表达式的记录依次对右表达式的值进行相关获取。
联接:先对左右两张表进行笛卡尔乘积运算。
CROSS APPLY:内部联接,两张表直接连接,不需要任何的关联条件,产生的结果就是这两张表的笛卡儿集等价于CROSS JOIN;
CROSS Apply 和 CROSS JOIN的区别:Cross Apply 可以在关联表子查询中用前一个关联表的字段的值,CROSS JOIN不可以。
比如:
SELECT * FROM t1 a CROSS APPLY t2 b WHERE a.id=b.id --相当于 inner join SELECT * FROM t1 a CROSS JOIN t2 b WHERE a.id=b.id --报错
OUTER APPLY:左外联接,右侧的表表达式返回一个空集合,CROSS APPLY运算符不会返回相应的左侧行,即OUTER APPLY和在派生表上进行LEFT JOIN是等同的
SELECT * FROM t1 a OUTER APPLY (select * from t2 where id=a.id) b -- 相当于 left join。
如果查询结果集需要用到表值函数对某个字段的值进行处理的话,可以使用CROSS APPLY。
-- 查询语文第一名,数学前两名,英语前五名的name,学科,分数,用cross apply实现方法如下
SELECT b.* FROM ( select Subject='Chiness',num=1 union all select 'Math',3 union all select 'English',5 )a cross apply (select top(a.num) * from Students where Subject=a.Subject )b
关于SQL Server中如何使用Apply关键字问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图