首页 > 其他分享 >SAP CDS view 里的 COALESCE 函数

SAP CDS view 里的 COALESCE 函数

时间:2023-11-01 13:07:32浏览次数:38  
标签:NULL vbak COALESCE View CDS SAP spfli view

在 SAP ABAP CDS (Core Data Services) View 中,COALESCE 函数是用于处理 NULL 值的一种功能。COALESCE 函数接受多个参数,并返回第一个非 NULL 值参数。这意味着如果第一个参数不为 NULL,则返回第一个参数的值;如果第一个参数为 NULL,则返回第二个参数的值;以此类推,直到找到第一个非 NULL 值参数为止。如果所有参数均为 NULL,则返回 NULL。

COALESCE 函数在 CDS View 中的应用十分广泛,它可以用于处理各种复杂的数据情况,例如默认值设置、空值替换等。在本文中,我们将详细说明 COALESCE 函数在 CDS View 中的使用,并提供一些实际示例来展示其功能。

首先,我们需要了解 COALESCE 函数的语法。在 CDS View 中,COALESCE 函数的语法如下:

COALESCE( value1, value2, ..., valueN )

其中,value1、value2 等为参数,可以是字段名、常量值或表达式。CDS View 将按照参数的顺序检查它们的值,返回第一个非 NULL 值参数。如果所有参数均为 NULL,则返回 NULL。

下面我们通过几个实际示例来详细说明 COALESCE 函数在 CDS View 中的应用:

示例 1:使用 COALESCE 设置默认值

假设我们有一个 CDS View,用于展示员工的信息,其中包括员工姓名和薪水。有时候,薪水字段可能为空,我们希望在查询结果中将其显示为默认值,比如 0。

@AbapCatalog.sqlViewName: 'ZEMPLOYEES'
@AbapCatalog.compiler.compareFilter: true
@AccessControl.authorizationCheck: #CHECK
@EndUserText.label: 'Employee Information'
define view ZEmployees as select from spfli
{
  key spfli.carrid,
  spfli.connid,
  spfli.cityfrom,
  spfli.cityto,
  spfli.countryfr,
  spfli.countryto,
  spfli.flighttype,
  spfli.distance,
  COALESCE(spfli.distance, 0) as distance_with_default
}

在上述示例中,我们使用 COALESCE 函数来设置 distance_with_default 字段的默认值为 0。如果 spfli.distance 字段为空(即为 NULL),则 distance_with_default 字段将显示为 0。

示例 2:使用 COALESCE 替换 NULL 值

在某些情况下,我们希望将 NULL 值替换为其他特定的值。例如,我们有一个 CDS View,用于显示订单信息,其中包括订单号和订单创建日期。如果订单创建日期为空,我们希望在查询结果中将其替换为 "N/A"。

@AbapCatalog.sqlViewName: 'ZORDERS'
@AbapCatalog.compiler.compareFilter: true
@AccessControl.authorizationCheck: #CHECK
@EndUserText.label: 'Order Information'
define view ZOrders as select from vbak
{
  key vbak.vbeln,
  vbak.erdat,
  COALESCE(vbak.erdat, 'N/A') as erdat_replaced
}

在上述示例中,我们使用 COALESCE 函数来将 erdat 字段的 NULL 值替换为字符串 "N/A",并将结果显示在 erdat_replaced 字段中。

示例 3:使用 COALESCE 进行复杂判断

COALESCE 函数还可以用于复杂的判断逻辑,返回满足条件的第一个非 NULL 值参数。例如,我们有一个 CDS View,用于显示销售订单的信息,其中包括订单号、订单日期和订单状态。我们希望在查询结果中,如果订单状态为空,则根据订单日期判断订单状态为 "已完成" 或 "未完成"。

@AbapCatalog.sqlViewName: 'ZSALESORDERS'
@AbapCatalog.compiler.compareFilter: true
@AccessControl.authorizationCheck: #CHECK
@EndUserText.label: 'Sales Order Information'
define view ZSalesOrders as select from vbak
{
  key vbak.vbeln,
  vbak.erdat,
  vbak.status,
  COALESCE(vbak.status, CASE WHEN vbak.erdat <= '20230730' THEN '已完成' ELSE '未完成' END) as status_with_default
}

在上述示例中,我们使用 COALESCE 函数结合 CASE 表达式来实现复杂的判断逻辑。如果 vbak.status 字段为空,将根据订单日期 vbak.erdat 判断订单状态为 "已完成" 或 "未完成",并将结果显示在 status_with_default 字段中。

总结

在 SAP ABAP CDS View 中,COALESCE 函数是用于处理 NULL 值的一种功能。它返回第一个非 NULL 值参数,可以用于设置默认值、替换 NULL 值或实现复杂的判断逻辑。通过在 CDS View 中使用 COALESCE 函数,我们可以更灵活地处理数据,提高查询结果的可读性和可用性。在实际开发中,合理应用 COALESCE 函数可以有效地优化数据处理,增强系统的功能和用户体验。

标签:NULL,vbak,COALESCE,View,CDS,SAP,spfli,view
From: https://blog.51cto.com/jerrywangsap/8120643

相关文章

  • 如何找到 SAP Fiori Elements 应用某个字段显示值具体的数据源试读版
    笔者将自己在SAP领域16年(2007~2023)的SAPUI5(Fiori)和OData开发的技术沉淀,进行了系统的归纳和总结,分别写成了三套由浅入深的学习教程,收到了不错的反响:零基础快速学习ABAP一套适合SAPUI5开发人员循序渐进的学习教程SAPOData开发实战教程-从入门到提高这三套教程都......
  • SAP Fiori Elements 应用里的 ui5.yaml 文件详解试读版
    本教程第4篇文章,我们介绍了本地启动SAPFioriElements应用的三种模式。4.SAPFioriElements本地应用启动的三种模式辨析以默认方式即命令行yarnstart启动之后,项目文件夹里的ui5.yaml文件会默认被加载并解析。ui5.yaml这个文件,在本地开发FreestyleUI5时也会遇到,笔......
  • SAP Fiori Elements 应用里的 ui5-local.yaml
    SAPFioriElements是SAP的一种开发框架,用于快速构建SAPFiori应用程序。SAPFioriElements应用程序的一个重要方面是模拟服务器(mockserver),它允许在本地开发环境中模拟OData服务,以便在没有真实后端服务的情况下进行开发和测试。ui5-local.yaml文件用于配置本地开发环境,......
  • SAP UI5 中的 sap-fe-mockserver
    SAPUI5是一种用于构建现代Web应用程序的开发框架,它是SAP(Systems,Applications,andProductsinDataProcessing)公司推出的一种前端技术。它提供了丰富的控件库、MVC(Model-View-Controller)架构模式、数据绑定、主题定制等功能,帮助开发人员构建直观、高度可定制且易......
  • 因为 SAP UI5 版本升级引起的问题又一例 - 如何分析问题根源
    本教程之前的文章,我们介绍了SAPUI5库文件版本相关的知识:SAPUI5应用开发教程之八十四-如何指定SAPUI5应用程序基于某个特定的版本运行同样一份源代码,使用不同的SAPUI5版本加载,行为可能会有所差异:SAPUI5应用开发教程之一百一十八-如何分析因为SAPUI5版本差异带来......
  • 通过 TCPView 还发现个流氓 KPKIService.exe 删掉
    叫统一安全中间件,就是个第三方做的key的安全检查,谁知道是哪年装的资料https://baijiahao.baidu.com/s?id=1717384219148345375&wfr=spider&for=pc---------------------------------------------生活的意义就是你自己知道你要做什么,明确目标。没有目标,后面都是瞎扯!https://p......
  • 将.View.dll文件反编译出来的*Views*.cs文件转换成.cshtml
    先使用反编译工具将.View.dll文件反编译放入文件夹,然后将文件夹整体复制进\src\viewcs2cshtml\viewcs2cshtml\bin\Debug\net6.0\viewcs复制完成之后运行程序,即可在复制进去的文件夹中看到Views/Areas文件夹暂不支持有asp-开头属性的控件例子还原前usingSystem;usingSystem......
  • datagridview消除自动生成的第一列
     方法:属性中 RowHeadersVisible设置为False效果: ......
  • uView组件库适配微信小程序
    1.打开官网 uView 官网2.在HbuilderX中集成插件sass,并新建项目。3.补充小程序id等信息后进行编译。4.根据官网下载-安装方式提示进行操作5.在HbuilderX中的工具→插件安装→插件市场安装将uView集成到你的小程序项目中去。(如果搜索不到可以直接点击uView中的链接下......
  • Android之WebView显示PDF文档
    参考:https://blog.csdn.net/Android_Cll/article/details/131641229https://cloud.tencent.com/developer/article/2301730Android项目新增js:/app/src/main/assets/wwwroot/index.js我新建了一个wwwroot放里面了。自己看着办。varurl=location.search.substring(1);PDFJS.......