ABAP中Literals的用法(untyped literal vs. typed literal)

2023-10-24 12:40

本文主要是介绍ABAP中Literals的用法(untyped literal vs. typed literal),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 什么是Literals ?

Literals的字面意思即“文字”。其实,Literals就是在ABAP代码中直接指定的一个字符串,但注意哦,这个字符串并不意味着其类型一定是string哦。

要弄清这个概念,就要清楚ABAP对于Literals 的定义和处理方式。

ABAP中,有两种类型的literal:

  • Numeric Literal: 数字文字
  • Character Literal: 字符文字
DATA lt_sflight TYPE TABLE OF sflight.SELECT * FROM sflight INTO TABLE @lt_sflightWHERE connid = 0017        " Numeric LiteralAND fldate = '20220101'  " Character LiteralAND currency = 'CNY'.    " Character Literal

对于Literal,我们可以使用符号&对Literal进行拼接。

WRITE: 'Hello' & ' ABAP' & ' 7.55'.

我们通过以上的例子,可以看到,Literal其实就是程序里直接指定了一个常量,使用时,并不需要指定类型,ABAP编译器会根据Literal的值,进行自动的转换。

2. Literals的转换规则

2.1 数字文字 Numeric Literals

数字文字由0到9的数字组成,它可以直接在前面加上一个加号(+)或减号(-)。

  • 当数字在【-2147483648 ~ 2147483647】范围之间时,编译器会给定其类型为 i
  • 当超过上述范围时,编译器会给定其类型为 p
  • 没有INT8的数字文字,如果需要可以通过CONV INT8()进行转换。
  • 数字文字不包含小数

2.2 字符文字 Character Literals

字符文字可以是文本字段 text field文本字符串 text string

  • 对于字符类型c的文本字段,其用单引号声明,最大长度为255;

  • 对于字符串类型string的文本字段,其用反引号声明。

WRITE: / 'This is John''s bike' .    " 单引号声明, 有要输出的单引号时,要转义单引号WRITE: /  `This is John's bike`.     " 反引号声明

对于字符文字的拼接,可以使用&拼接符,但要注意c类型的文字是不能与string类型的文字进行混合拼接的。

WRITE: / 'Hello' & ' ABAP' & ' 7.55'. " ok WRITE: /  `Hello` & ` ABAP` & ` 7.55`. " okWRITE: / 'Hello' & ' ABAP' & ` 7.55`. " wrong

对于字符文字的声明和拼接,要注意:

  • 使用文字操作符 & 组合的字符文字,最大长度是 255,因为ABAP代码编辑器的最大长度为255,字符文字声明时,是不能换行的。
  • 对于长于255的字符文字,只能在运行时连接,例如使用连接操作符 &&

下面展示了将4种不同的操作符拼接成一个字符串string,

DATA text TYPE string VALUE `Hello`. text  = text && ` ` &&  'world' && |!|.  " 双竖线是string template的用法

2.3 String Template 字符串模板

字符串模板是通过两个竖线 | … | 来生成一个没有长度限制的字符串的方法。

  • 拼接两个字符串模板生成的字符串时,可以通过 & 或 && , 两者的效果一致。

辨析几种不同的拼接:

方式1: 受255长度限制的拼接
`...` &  `...` 
'...' &  '...' 方式2: 不受255长度限制的拼接
|...| &  |...|    等同于    |...| && |...|  等同于    `...` && `...` 

使用字符串模板最大的好处就是,可以在其内部,直接引用变量,所有在双竖线范围内的字符都会被认定为文字,包括空格;对于变量,可以用小括号进行引用:

Data result type string.
result = |Hello { sy-uname }!|. 

2.4 字符文字的潜在问题

通过以上介绍,可以看到,字符文字在使用时,其实并没有直接指定类型,而是通过编译器自动识别类型,这就导致了,在程序运行过程中,会存在潜在的类型转换。

再回到最开始的例子:

SELECT * FROM sflight INTO TABLE @lt_sflightWHERE connid = 0017        " Numeric Literal  --> 将 i类型 自动转换为 NUMC 类型AND fldate = '20220101'  " Character Literal --> 将 c类型 自动转换为 DATS 类型AND currency = 'CNY'.    " Character Literal --> 将 c类型 自动转换为 CUKY 类型

这就意味着,可能会出现潜在的转换问题。

3. ABAP 7.55及以上版本的typed literal

针对这一问题,在ABAP 7.55以及以上版本,ABAP支持了在SQL语句中,对literal 类型的显示指定。
在这里插入图片描述
这样我们在SQL中就可以写成下面形式,进而在编译时就发现代码中,可能存在的类型转换问题,避免程序在运行时才发现类型转换的问题。

SELECT * FROM sflight INTO TABLE @lt_sflightWHERE connid = numc`0017`        AND fldate = dats`20220101`    AND currency = cuky`CNY` .  

同样的概念也适用于CDS View,更多的信息可以查看这篇SAP官方博客。

4. 小结

本文总结了ABAP编程中,对于literal的常见处理方式,辨析了c类型与string类型的literal,包括如何声明literal?如何拼接两个literal?并介绍了如何在ABAP 7.55以上使用指定类型的Literal。

本博客专注于技术分享,干货满满,持续更新。 欢迎关注❤️、点赞👍、转发📣!

这篇关于ABAP中Literals的用法(untyped literal vs. typed literal)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/275226

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

Mysql中isnull,ifnull,nullif的用法及语义详解

《Mysql中isnull,ifnull,nullif的用法及语义详解》MySQL中ISNULL判断表达式是否为NULL,IFNULL替换NULL值为指定值,NULLIF在表达式相等时返回NULL,用... 目录mysql中isnull,ifnull,nullif的用法1. ISNULL(expr) → 判

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.