位置: 编程技术 - 正文

SQLServer APPLY表运算符使用介绍(sql server数据表)

编辑:rootadmin
新增的APPLY表运算符把右表表达式应用到左表表达式中的每一行。它不像JOIN那样先计算那个表表达式都可以,APPLY必选先逻辑地计算左表达式。这种计算输入的逻辑顺序允许吧右表达式关联到左表表达式。

  APPLY有两种形式,一个是OUTER APPLY,一个是CROSS APPLY,区别在于指定OUTER,意味着结果集中将包含使右表表达式为空的左表表达式中的行,而指定CROSS,则相反,结果集中不包含使右表表达式为空的左表表达式中的行。

  用几个例子解释这个会更清晰。

  例1:CROSS APPLY 形式

  比如:LargeTable表中的某一列存储的数据是以“:”号分隔的数据,我们处理的时候,可能要先把这个值,先分隔,然后把分隔后的每个值单独一行放在一张表中,然后对这个表做处理。

  原始数据(LargeTable表):  

  为了简单,我们先拿其中id=2的一行处理,这些以:号分隔的数据,可能是我们某张表的主键(t1),我们可能需要把这些数值提出来,放在一张临时表中,和t1表关联,做一些处理。

  处理这个分隔的数据结果如下图:

  

  如果用之前的版本处理这个操作的话,应该很发杂,暂时没想到怎么处理,如果有人实现过,可以提示一下。

  这只是用其中一行做的处理,如果我们用上图的3行都做这样处理,把三行以:号分隔的数值都放在一个表中,该怎么处理呢?

  今天的主角APPLY该闪亮登场了。用APPLY表运算符一行语句就能处理以上操作。处理的结果如下图:

  

  是不是很简单。 需要额外定义的就是那个自定义表值函数(split),这是我在网上找的,类似.Net中Split操作,代码如下:例2:OUTER APPLY 形式

  场景:有个供货商表(Supplier)和供货商产品表(Products),我们要取每一个供货商中单价最高的两个产品。

  供货商表:

  

  供货商产品表:

  

  首先,我们创建一个自定义表值函数(dbo.fn_top_products),该函数根据供货商ID返回单价最高的两个商品。好,前期的数据都已经准备好了,下面让我们试试用OUTER APPLY形式来查询,会出现什么结果。 执行以下语句: 执行结果如下:

   

  注意最后为NULL的记录,reed公司因为没有商品,所以单价为NULL了。

  如果用CROSS APPLY形式,执行以下查询:

生成的输出结果如下:

    

  大家看出OUTER APPLY和CROSS APPLY的区别了吧。

  再次说一下APPLY的执行过程,它先逻辑计算左表表达式(以上的LargeTable表),然后把右表达式(以上的自定义表值函数Split)应用到左表表达式的每一行。实际是把外部查询的列引用作为参数传递给表值函数。

推荐整理分享SQLServer APPLY表运算符使用介绍(sql server数据表),希望有所帮助,仅作参考,欢迎阅读内容。

SQLServer APPLY表运算符使用介绍(sql server数据表)

文章相关热门搜索词:sqlserver lpad,sqlserver ag,sql server数据库表,sql server表在哪里,sql server 表,sql server 表,sql server数据表,sql server 表,内容如对您有帮助,希望把文章链接给更多的朋友!

SQLServer 查询当前服务器有多少连接请求的语句 SQLServer本身提供了这么一个DMV来返回这些信息,它就是sys.dm_exec_sessions。比如在我的机器上做一下查询:SELECT*FROMsys.dm_exec_sessionsWHEREhost_nameISNOTNULL如图

正解SQLSEVER sql排序(按大小排序) 今天在论坛上看到一个问题,如下:解决这个问题,Insus.NET写了一个函数,可以方便以后的扩展,如果数值出现TB或是或更高时,可以只改这个函数即

SQLServer与SQLServer数据库同步图文教程 1,复制简介简单的说,复制是获取一个或多个数据库的过程,它系统的针对出入不同数据库的数据,提供基于规则的拷贝机制。复制分为三种角色,1,发

标签: sql server数据表

本文链接地址:https://www.jiuchutong.com/biancheng/319345.html 转载请保留说明!

上一篇:MSSQL 大量数据时,建立索引或添加字段后保存更改提示超时的解决方法(mysql 大量数据)

下一篇:SQLServer 查询当前服务器有多少连接请求的语句(sqlServer查询当前ip地址)

  • 收到政府的补贴收入现金流量表填哪里
  • 交印花税合同上每个月价格要一样吗
  • 未到账的银行存款怎么取
  • 超市的小票能重开吗
  • 流动负债占比低于50%,是什么结构类型
  • 其他收益怎么用
  • 手机专票 一般纳税人能抵扣吗
  • 工商银行资产负债表
  • 财产性收入是非劳动性收入吗
  • 公务出差乘坐飞机
  • 企业股权融资方式有
  • 所得税退税会计账务怎么处理
  • 销售亏损原因分析范文
  • 有留抵税额的会计处理
  • 给员工发中秋福利
  • 管理会计的目标包括多选题
  • 一个人有多份工作
  • 跨年度收入计算的增值税如何入账?
  • 小规模纳税人物流服务税率
  • 公司租赁厂房开几个点发票
  • 关于设备安装调试的说法
  • 怎么做销售二手车
  • 在建期间费用怎么处理?
  • 分支机构的季度所得税务报表是填合并报表吗
  • 收到房租的增值税税率
  • 按年缴纳年金的企业缴费部分,应按照全年一次性奖金
  • 生产调试消耗原材料如何做账?
  • 成本分摊会计
  • linux ctrl c和ctrl z
  • 偶然所得是什么科目
  • 公益性捐赠所得税税前扣除标准
  • 结转已经销售商品成本的分录
  • 公司委托第三方缴纳社保合法吗
  • php表单系统源码
  • 苹果客服人工24小时
  • 坏账准备的会计科目
  • Php结合wordpress开发,需要学会什么
  • Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)
  • 代扣费用会计分录
  • 营改增后租金收入交什么税
  • Python中__slots__限制属性
  • 客户多付款不要了多这部分是哪种收入?
  • 一般纳税人公司出售旧车怎么开票
  • 小规模企业每月收入多少可以不纳税
  • 差旅费津贴属于应付职工薪酬吗
  • ibm db2认证
  • 收到发票未收到货物
  • 企业跨区变更地址迁入地核验码怎么查询
  • 基本户能转账吗现在
  • 用友t6反记账步骤
  • 收到员工交来的宿舍费
  • 全资子公司可以转让吗
  • 运费会计科目怎么做
  • 失控发票补缴税款后又被稽查
  • 经营杠杆系数的经济含义
  • 一般纳税人只开普票不开专票免税
  • 融资租赁出租人与承租人之间形成债权债务关系
  • 发票怎么跨月作废申请
  • 餐费发票报销需提供清单吗
  • 会计软件包括
  • 虚拟机中安装虚拟机
  • windows route metric
  • Win7笔记本怎么连接wifi
  • ubuntu 编译软件
  • winpsd.exe - winpsd是什么进程
  • macos邮件
  • ubuntu系统键盘无用
  • centos6.8升级centos7
  • win8在哪里看安装的所有程序
  • 如何选择适合你的颂钵
  • android:excludeFromRecents="true"
  • ssh执行远程命令 参数
  • 如何搭建python项目架构
  • jquery如何调用
  • js选中文字
  • 广东省电子学校
  • 公司缴税款可以退税吗
  • 支部组织生活会流程
  • 普惠性税收优惠政策例子
  • 财务公司怎么做
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设