ABAP 7.55 新特性 (二) ABAP SQL部分
上一篇文章ABAP 7.55 新特性 (一)介绍了ABAP 7.55中除ABAP SQL外的更新内容,本篇是剩余的ABAP SQL更新部分。
1. 新聚合函数ALLOW_PRECISION_LOSS
ABAP SQL现在支持新的聚合函数ALLOW_PRECISION_LOSS
,它可以和SUM
结合使用,以降低准确性为代价,提升性能,
示例代码,
REPORT demo_allow_precision_loss. CLASS demo DEFINITION.
PUBLIC SECTION.
CLASS-METHODS main.
ENDCLASS. CLASS demo IMPLEMENTATION.
METHOD main. TYPES result_type TYPE p LENGTH 6 DECIMALS 2.
DATA: allow_precision_loss_result TYPE result_type,
normal_sum_result TYPE result_type. DELETE FROM demo_expressions.
INSERT demo_expressions FROM TABLE @(
VALUE #( ( id = 'X' dec2 = '2.119999' )
( id = 'Y' dec2 = '2.118888' )
( id = 'A' dec2 = '1.13999' )
( id = 'Z' dec2 = '2.668888' )
) ). SELECT SUM( CAST( dec2 AS DEC( 10,2 ) ) ) AS sum1
FROM demo_expressions INTO @normal_sum_result. SELECT allow_precision_loss( SUM( CAST( dec2 AS DEC( 10,2 ) ) ) )
AS sum1
FROM demo_expressions INTO @allow_precision_loss_result. cl_demo_output=>write_data( allow_precision_loss_result ).
cl_demo_output=>write_data( normal_sum_result ).
cl_demo_output=>display( ).
ENDMETHOD.
ENDCLASS. START-OF-SELECTION.
demo=>main( ).
2. 窗口函数中的可选窗口帧
可选窗口帧规范允许定义窗口内行的子集,该子集称为帧。 帧是根据当前行确定的,这使得它可以在窗口内移动。
3. 新窗口函数FIRST_VALUE和LAST_VALUE
ABAP SQL现在在窗口表达式中支持以下新窗口函数:
4. 新的日期/时间转换函数
现在,ABAP SQL支持以下新的日期/时间转换函数:
TSTMPL_TO_UTCL
和TSTMPL_FROM_UTCL
DATS_TO_DATN
和DATS_FROM_DATN
TIMS_TO_TIMN
和TIMS_FROM_TIMN
5. 新的时间戳函数
现在,ABAP SQL支持以下新的时间戳函数:
UTCL_CURRENT
,UTCL_ADD_SECONDS
和UTCL_SECONDS_BETWEEN
.
6. 新的日期函数
现在,ABAP SQL支持以下新的日期函数:
DATN_DAYS_BETWEEN
,DATN_ADD_DAYS
和DATN_ADD_MONTHS
.
7. ORDER BY子句后新的附加项
现在,ABAP SQL支持以下新的日期函数ORDER BY子句后新的附加项:
NULLS FIRST
和NULLS LAST
.
8. 新的聚合函数
现在,ABAP SQL支持以下新的聚合函数:
MEDIAN
,STDDEV
,VAR
,CORR
和CORR_SPEARMAN
.
9. 新的几何变换函数
现在,ABAP SQL支持以下新的几何变换函数:
as_geo_json
10. SQL条件修正
操作符IN现在可以用于返回值元组的子查询。
示例代码
DATA cityfrom TYPE spfli-cityfrom VALUE 'Frankfurt'.
DATA cityto TYPE spfli-cityto VALUE 'New York'.
cl_demo_input=>new(
)->add_field( CHANGING field = cityfrom
)->add_field( CHANGING field = cityto
)->request( ).
cityfrom = to_upper( cityfrom ).
cityto = to_upper( cityto ). SELECT *
FROM spfli
WHERE ( carrid, cityfrom, cityto )
IN ( ( 'LH', @cityfrom, @cityto ),
( 'UA', @cityfrom, @cityto ) )
INTO TABLE @DATA(itab). cl_demo_output=>display( itab ).
SQL函数和cast表达式目前可以用在比较运算符的右侧。
11. 新的窗口函数NTILE
ABAP SQL现在在窗口表达式中支持以下新窗口函数:
12. SELECT, INTO target修改
在使用SELECT, INTO target
时,宿主变量可以内联声明,即便FROM子句是动态的,只要所有SELECT清单是静态的。以前,结果集的结构,包括SELECT列表、FROM子句和任何indicator都需要是静态的。
13. 新的类型转换函数to_clob和to_blob
ABAP SQL现在在窗口表达式中支持新的类型转换函数to_clob
和to_blob
。
14. 新的货币转换函数currency_conversion
ABAP SQL现在支持新的货币转换函数currency_conversion
。
示例,
DATA currency TYPE c LENGTH 5 VALUE 'USD'. ... SELECT FROM demo_prices
FIELDS id,
currency_conversion(
amount = amount,
source_currency = currency,
target_currency = @currency,
exchange_rate_date = @sy-datlo,
round = 'X',
on_error =
@sql_currency_conversion=>c_on_error-fail )
AS amount,
@currency AS currency
INTO TABLE @DATA(converted_prices_asql).
15. 现在可以在SQL表达式中使用streaming和locators
现在可以在SQL表达式中使用streaming和locators,比如TO_CLOB
, TO_BLOB
和AS_GEO_JSON
.
16. 基本SQL表达式支持更多类型
基本SQL表达式现在可以支持字典类型STRING和RAWSTRING.
17. Hierarchy载入选项
对于hierarchy生成器HIERARCHY
,现在可以通过新的附加项LOAD BULK|INCREMENTAL|load_option
指定载入策略。
18. 指定类型的字面量
现在可以在ABAP SQL中使用多种ABAP字典类型的指定类型的字面量。
语法:... dtype...
例如,
SELECT *
FROM demo_ddic_types
WHERE int8 = int8`32984723948723`
INTO TABLE @DATA(result).
19. 新的字符函数
ABAP SQL现在支持一些新的正则处理函数,比如REPLACE_REGEXPR
, LIKE_REGEXPR
和 OCCURRENCES_REGEXPR
20. 在UPDATE FROM中指定更新列
现在可以在UPDATE FROM子句中通过set indicators指定更新列。
21. 严格模式
如果用到了上面列出的ABAPSQL中的任一新特性,语法检查会以严格模式运行。
原始文档链接:https://help.sap.com/doc/abapdocu_755_index_htm/7.55/en-US/index.htm?file=abennews-755-abap_sql.htm
ABAP 7.55 新特性 (二) ABAP SQL部分的更多相关文章
- ABAP 7.55 新特性 (一)
最近几天,SAP S4 2020对应的ABAP 7.55的新版文档已经出现.本文翻译了ABAP SQL之外的更新部分.ABAP SQL的更新比较长,会再之后单独成篇. 译者水平有限,如有错误,请评论指 ...
- ABAP 7.50 新特性 – Open SQL中的宿主表达式和其它表达式
在长期的停滞后,Open SQL的发展终于从沉睡中醒来.从ABAP 7.40开始,SAP推进了某些关键的改变,以尽可能地包含SQL92中的特性,并提供与ABAP CDS中的DDL里面的SELECT一样 ...
- ABAP 7.50 新特性之另一个CORRESPONDING
在ABAP中,存在着一条法则:同样的名称代表的不一定是同样的东西(具体可看最近的相关讨论). 但是如你们所知的,存在着一个很好的例外: 所有涉及到使用CORRESPONDING为结构赋值的关键字的语法 ...
- Atitit.数据库新特性战略规划 mssql sql server 2008 SQL2012 SQL2014
Atitit.数据库新特性 mssql sql server 2008 SQL2012 SQL2014 1. Sql2012 新特性 1 1.1. 增加了Sequence对象. 1 1.2. 新的分页 ...
- HTML5 十大新特性(二)——表单新特性
H5的表单新特性可以分为两大类. 一.10个input的type值 1.email:邮件输入域,在表单提交时提供简单的邮箱格式验证,并弹出一个提示窗口. 2.url:地址输入域,在表单提交时提供简单的 ...
- JAVA 8 主要新特性 ----------------(二)JDK1.8优点概括
一.JDK1.8优点概括 1.速度更快 由于底层结构和JVM的改变,使得JDK1.8的速度提高. 2.代码更少(增加了新的语法 Lambda 表达式) 增加新特性Lambda表达式的 ...
- 深入理解java虚拟机---jdk8新特性(二)
1.jdk8新特性 1.新特性 2.lambda函数表达式的作用 A: 替换内部类 B:对集合的操作并行化
- 类的加载、时机、反射、模板设计、jdk7/jdk8新特性(二十六)
1.类的加载概述和加载时机 * A:类的加载概述 * 当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过加载,连接,初始化三步来实现对这个类进行初始化. * 加载 * 就是指将class文 ...
- JDK8新特性(二) 流式编程Stream
流式编程是1.8中的新特性,基于常用的四种函数式接口以及Lambda表达式对集合类数据进行类似流水线一般的操作 流式编程分为大概三个步骤:获取流 → 操作流 → 返回操作结果 流的获取方式 这里先了解 ...
- 010-jdk1.8版本新特性二-Optional类,Stream流
1.5.Optional类 1.定义 Optional 类是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象. Optional 是个 ...
随机推荐
- vue项目中添加水印效果
新建js文件:例如warterMark.js 'use strict' let watermark = {} let setWatermark = (str) => { let id = '1. ...
- 感悟:FPGA的串行及并行设计思路
前言 FPGA设计过程中, 会遇到大量的串行转并行或者并行转串行的问题; 这些问题主要体现在FPGA对于速度和面积的均衡上; 一般而言, FPGA使用并行的设计可以提高处理的速度, 消耗更多的资源; ...
- KingbaseES 数据表复制语句的功能差异
Kingbase 数据表复制操作 数据库使用过成中,经常会遇到在现有的表结构基础上,对表结构进行复制.在KingbaseES数据库可以采用select into,create table as sel ...
- 最大堆(MaxHeap)
性质 二叉堆是一颗完全二叉树,而完全二叉树是把元素排列成树的形状. 堆中某个节点的值总不大于其父节点的值最大堆(相应的可以定于最小堆) // 返回完全二叉树的数组表示中,一个索引所表示的元素的父亲节点 ...
- 手写数字图片识别——DL 入门案例
Deep Learning Demo of Primary 下面介绍一个入门案例,如何使用TensorFlow和Keras构建一个CNN模型进行手写数字识别,以及如何使用该模型对自己的图像进行预测.尽 ...
- JDK14性能管理工具:jstack使用介绍
目录 简介 jstack的命令格式 jstack的使用 总结 简介 在之前的文章中,我们介绍了JDK14中jstat工具的使用,本文我们再深入探讨一下jstack工具的使用. jstack工具主要用来 ...
- ABA问题的本质及其解决办法
目录 简介 第一类问题 第二类问题 第一类问题的解决 第二类问题的解决 总结 简介 CAS的全称是compare and swap,它是java同步类的基础,java.util.concurrent中 ...
- OpenHarmony 3.2 Beta多媒体系列——音视频播放框架
一.简介 媒体子系统为开发者提供一套接口,方便开发者使用系统的媒体资源,主要包含音视频开发.相机开发.流媒体开发等模块.每个模块都提供给上层应用对应的接口,本文会对音视频开发中的音视频播放框架做一 ...
- Go 语言 Printf 函数和格式化动词详解
Printf() 函数可以使用多种格式化动词对输出进行格式化.下面是可以与所有数据类型一起使用的一些通用格式化动词: 以下动词适用于所有数据类型: 动词 描述 %v 以默认格式打印值 %#v 以 Go ...
- Excel分析师的工资能一直飙升,原因其实是...
世界上的数据分析师分为使用Excel的分析师和其他分析师两类. 即使在互联网数据分析界,java遍街头,Python不如狗,Excel也是不可替代的. 上班前以为自己是西装笔挺的Excel数据分析师, ...