S/4 HANA 1709 已经在几个月前发布,随之而来的是ABAP 7.52。

本文翻译了更新文档中有关Open SQL的部分。

如果读者是Open SQL的新手,请不要从本文看起。更合适的教程是:A complete guide to OpenSQL statements – Step-by-step tutorial with screenshots

本文链接:http://www.cnblogs.com/hhelibeb/p/7941300.html

1,内表作为数据源

现在可以将内表指定为查询语句的数据源。如果内表数据需要传递给数据库的话,则只能在部分数据库上运行。

例子:

DATA itab TYPE HASHED TABLE OF scarr
WITH UNIQUE KEY mandt carrid. IF NOT cl_abap_dbfeatures=>use_features(
EXPORTING
requested_features =
VALUE #( ( cl_abap_dbfeatures=>itabs_in_from_clause ) ) ).
cl_demo_output=>display(
`System does not support internal tables as data source` ).
RETURN.
ENDIF. itab = VALUE #( ( carrid = 'LH' carrname = 'L.H.' )
( carrid = 'UA' carrname = 'U.A.' ) ). SELECT scarr~carrid, scarr~carrname, spfli~connid
FROM @itab AS scarr
INNER JOIN spfli ON scarr~carrid = spfli~carrid
INTO TABLE @DATA(result)
##db_feature_mode[itabs_in_from_clause]. cl_demo_output=>display( result ).

2,关系表达式

条件表达式现支持以下情况:

  • 可以对字符类数据类型大小比较,并且不再限制N类型。
  • 操作符BETWEEN不再限制N类型,SQL表达式现在可以在右侧使用了。
  • 现在也支持LIKE操作符。

3,转换函数

新的类型转换函数BINTOHEXHEXTOBIN现在可以在SQL表达式中把byte strings转换为character strings,这种功能在CAST表达式中是不可行的。

示例程序,可以看到两种转换方式的结果是一样的:

 SELECT SINGLE id AS uuid32, hextobin( id ) AS uuid16
FROM iwreferenc
WHERE tcode = 'SE38'
INTO @DATA(wa). IF sy-subrc = .
DATA uuid16 LIKE wa-uuid16.
cl_system_uuid=>convert_uuid_c32_static(
EXPORTING
uuid = wa-uuid32
IMPORTING
uuid_x16 = uuid16 ).
ASSERT wa-uuid16 = uuid16.
ENDIF.

4,路径表达式

以下特性现在在路径表达式(path expression)中可用:

  • 在传参的空白部分、属性方括号的空白部分和斜杠\前的位置,路径表达式可以分割为多个代码行。
  • 目标数据也是CDS表函数(table function)的时候,也可以使用Association了。
  • 参数可以在路径表达式association的后面传递。由此可以指定带有参数的CDS entities作为association的数据源。
  • 在路径表达式中,现在可以指定join表达式的cardinality和类型作为属性。
  • association的过滤条件现在可以在路径表达式中指定。

5,访问控制

新的关键字WITH PRIVILEGED ACCESS可以关闭CDS的访问控制

6,子查询中的ORDER BY和UP TO, OFFSET

在子查询中,现在可以使用ORDER BY子句和附加项UP TO, OFFSET了。不过,不是所有数据库都支持在子查询中运行ORDER BY。

注意:在子查询中,UP TO只能用在ORDER BY子句后面,附加项OFFSET也只能在UP TO后面指定。

7,LFET OUT JOIN中的Cardinality

在LFET OUTER JOIN中,可以用附加项ONE TO MANY指定Cardinality。它可以被SAP HANA识别为一种优化说明。

8,SELECT列表中的FOR ALL ENTRIES IN和字符串

在先前的严格模式语法检查中,SELECT语句的附加项FOR ALL ENTRIES IN不能和SELECT列表中类型为STRING和RAWSTRING或者LCHR和LRAW的列一起出现。现在这个限制已经被移除,语法检查只会对此提示一个警告,而不是错误。

9,严格模式的语法检查

如果你用到了上面列出的Open SQL中的任一新特性,语法检查会以严格模式运行。

10,Client处理

在切换Client读取CDS entities时,附加项USING CLIENTCLIENT SPECIFIED会应用以下(更严格的)规则:

  • CDS访问控制不会在跨Client访问时工作。因此,附加项USING CLIENTCLIENT SPECIFIED只能在CDS entities的访问控制被关闭的时候使用,即注解为AccessControl.authorizationCheck.#NOT_ALLOWED,或者查询语句中使用了上文5中的WITH PRIVILEGED ACCESS时。
  • 路径表达式只能在自动Client处理打开的时候使用。不可以使用CLIENT SPECIFIED,以防路径表达式中的association中的FROM子句中的目标数据是指定Client(Client-specific)的数据源(?),association的源数据源也不可以是指定客户端的。

11,Open SQL中的代理服务

CL_OSQL_REPLACE可以在ABAP Unit单元测试中将数据库访问重定向至访问其它数据库的Open SQL。

该类只能在测试类中使用。

示例程序:DEMO_CL_OSQL_REPLACE

相关阅读:ABAP 7.50 新特性

       ABAP 7.40, SP08 中的 Open SQL 新特性

      ABAP 7.53 中的ABAP SQL(原Open SQL)新特性

ABAP 7.52 中的Open SQL新特性的更多相关文章

  1. ABAP 7.40, SP08 中的 Open SQL 新特性

    1,使用 data_source~*指定列 在7.40, SP08中,可以在SELECT语句中使用data_source~*来指定选取不同的数据库表.视图的全部列来作为结果集.它也可以和单独指定的列c ...

  2. ElasticSearch7.3学习(三十)----ES7.X SQL新特性解析及使用Java api实现sql功能

    一.ES7 sql新特性 1.1 数据准备 创建索引及映射 建立价格.颜色.品牌.售卖日期 四个字段 PUT /tvs PUT /tvs/_mapping { "properties&quo ...

  3. 简单理解ECMAScript2015中的箭头函数新特性

    箭头函数(Arrow functions),是ECMAScript2015中新加的特性,它的产生,主要有以下两个原因:一是使得函数表达式(匿名函数)有更简洁的语法,二是它拥有词法作用域的this值,也 ...

  4. Java 9中的 9个 新特性

    Java 9 中的 9个 新特性 java 7 2011发布,Java 8 2014发布,java9发布于2017年9月21日. 你可能已经听说过 Java 9 的模块系统,但是这个新版本还有许多其它 ...

  5. 【译】.NET 5. 0 中 Windows Form 的新特性

    自从 Windows Form 在 2018 年底开源并移植到 .NET Core 以来,团队和我们的外部贡献者都在忙于修复旧的漏洞和添加新功能.在这篇文章中,我们将讨论 .NET 5.0 中 Win ...

  6. 【C#】第1章 VS2015中C#6的新特性

    分类:C#.VS2015 创建日期:2016-06-12 一.简介 VS2015内置的C#版本为6.0,该版本提供了一些新的语法糖,这里仅列出个人感觉比较有用的几个新功能. 二.几个很有用的新特性 注 ...

  7. Visual Studio 2015 RC中的ASP.NET新特性和问题修正

    (此文章同时发表在本人微信公众号"dotNET每日精华文章") 微软在Build大会上发布了Visual Studio 2015 RC,这也预示着Visual Studio 201 ...

  8. 在 vs2017 中使用 C# 7 新特性。

    几个概念区分: 1.C#   C# 是一种.net 语言,与此类似的还有 vb,F#.不同版本的语言要配合相应的解释器才能发挥作用.目前 最新版本 为 C# 7.3. 2.VS        VS 是 ...

  9. Oracle12c 中RAC功能增强新特性之ASM&Grid

    1.    自动存储管理(ASM)方面的增强 1.1.   Flex ASM 在典型的网格架构安装中,每个节点有自己的ASM实例运行并扮演该节点上数据库的存储容器的角色,对这种安装配置,存在单点失败的 ...

随机推荐

  1. LINUX 笔记-ln 命令

    给文件创建软链接 命令:ln -s log2013.log link2013 给文件创建硬链接 命令:ln log2013.log ln2013

  2. MongoDB全文检索

    1. 全文检索概念: 全文检索是对每一个词建立一个索引,指明该词在文章中出现的次数和位置,当用户查询时,检索程序就根据事先建立的索引进行查找,并将查找的结果反馈给用户的检索方式.  (暂时不支持中文) ...

  3. LeetCode 495. Teemo Attacking (提莫攻击)

    In LOL world, there is a hero called Teemo and his attacking can make his enemy Ashe be in poisoned ...

  4. LeetCode 53. Maximum Subarray(最大的子数组)

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  5. (原创)(四)机器学习笔记之Scikit Learn的Logistic回归初探

    目录 5.3 使用LogisticRegressionCV进行正则化的 Logistic Regression 参数调优 一.Scikit Learn中有关logistics回归函数的介绍 1. 交叉 ...

  6. C++ 对象成员函数(非静态方法)

    1.神奇的inline语法与语义 inline语义C99和C++98都有.之前在单源文件编写的时候一直没有发现问题,但是一考虑到多文件的链接,就发现矛盾了. 一些inline的原则: 1. inlin ...

  7. 三、第一个IDEA创建的MAVEN工程——JavaWeb点滴

    一.Maven是什么? Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个 ...

  8. webpack学习(一)

    1.首先建立一个webpack项目,然后新建文件demo2,在demo2下新建src文件,index.html文件,初始化项目 (npm init --yes)得到package.json 2.全局安 ...

  9. C++11 static_assert

    C++11 static_assert C++0x中引入了static_assert这个关键字,用来做编译期间的断言,因此叫做静态断言. 其语法:static_assert(常量表达式,提示字符串). ...

  10. Interviewe

    Interviewe Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ...