SAP ABAP中的数据类型 Data Types

简单来说分两种:

  1. 数据字典里定义的
  2. 在ABAP程序里定义的

1. ABAP数据字典里的

1.1 数字型的

用在数学计算里的,表达式里的,表序号里的。

Interger整数型
INT1 : 1字节整数,0-255 (2的8次方-1)
INT2 : 2字节整数,-32768-32767(2的15次方-1,有一位是符号位)
INT4 : 4字节整数,-2147483648-2147483647(2的31次方-1)

SAP内部使用的INT1和INT2分别对应b和s。但是这两种预定义的不能被外部开发用上。
DEC小数型:Packed number
一般在BW里面能看到Curr的类型就是in BCD format,是Binary Coded Decimal。二进制编码小数
在这里插入图片描述
二进制编码高效展示小数,p类型就是会定义总长度和小数位数。Packed类型是CURR,QUAN和DF34_DEC,DF16_DEC的内部展示类型。我们定义一般写成:
Data: amount type p length 8 decimals 2.

Floating 浮点型
小数浮点型,相对于定点数而言,浮点数利用指数使小数点的位置可以根据需要而上下浮动,从而可以灵活地表达更大范围的实数。
这个在计算机组成原理里有。定点数小数点固定。不需要额外存储空间来存储小数点。只有符号位在最前面需要占一位bit。
但是定点数存储大范围的数值就不好搞了,我得把所有数都存下来,这就不如用科学计数法来的省空间了。所以浮点型借鉴十进制的科学计数法。计算机中的浮点数计算方式:
K=(-1)^ SM2^N ,其中,S代表符号位,M代表尾数,N代表阶码

主要就是为了让有限的计算机存储空间来存放大范围的数值。

小数浮点数:
DF16_DEC
DF16_RAW
DF34_DEC
DF34_RAW

ABAP 二进制浮点类型FLTP长度定为16位,基于EEE754的标准,这个标准就是说在不同平台相同的浮点数的表示结果得一样。

小数浮点型和FLTP的区别在于,FLTP是个二进制类型,对应ABAP类型f.由于有些小数不能完全转换为二进制,所以这个不是100%精确的。所以一般不在需要高精度计算的场景比如财务或者税务报表里使用,几乎所有的FLTP都能用DEC 类型。所以说用P就够了。

1.2 字符型

字符串或者字符数据
character
1~30000个字符数据,表格里最大放1333位,这也是BW里infoobject的最大text长度。而且不能用在表键。
string
SSTRING short string,1-1333长度
STRING-256-无限长(实际受可寻址的范围限制,最大2GB,内表也是最大2GB)

1.3 字节型

用来存储开发任务里的字节链。

RAW–长度为1-32000位的字节字符串。对于表字段,最大值为255。

LRAW–长度为256-32000位的长字节字符串

RAWSRING–长度为256无限长的BLOB字符串

RAW和LRAW类型具有对应的ABAP类型x,而RAWSRING类型对应于xstring类型。LRAW将来不用了。

1.4 特殊类型

日期/时间类型

DATS YYYYMMDD --对应d类型。从数据库读或者写的时候不是这个格式来的,在Dynpros里显示为这个格式。
TIMES HHMMSS,也是在Dynpros里显示的。对应t类型。
ACCP过账期间的字符表示:YYYYMM

特殊字符类型
NUMC 字符,最长255位,但是只用来存储数字。对应n
CLNT char3
LANG char1

货币/数量字段
CURR–用于存储货币的类型,技术上表示为长度为1-31的packed number。

CUKY–货币字段的货币键,按字符类型显示。最大长度为5位。

QUAN–用于以特定单位存储数量的类型,技术上表示为长度为1-31 packed number。

UNIT–数量字段的单位键,由字符类型表示。最大长度为3位置。

货币和数量字段是用于按功能属性存储数据的特殊字段。所有货币和数量字段必须与对应的关键字段(CUKY和UNIT)相关联,否则表格将无法通过验证。所有CUKY字段只能包含TCURC表中的值,而所有UNIT字段只能包含T006表中的值。

2. 预定义的ABAP数据类型

2.1 预定义数字型

b -INT1
s - INT2
标准SAP程序使用

i- INT4 在ABAP程序使用
p- 最大长度16字节
decfloat16–用于存储字典类型DF16_DEC和DF16_RAW的十进制浮点数。最大长度为8字节。

decfloat34–用于存储字典类型DF34_DEC和DF34_RAW的十进制浮点数。最大长度为16字节。

f–二进制浮点数类型,类似于FLTP DDIC类型。高精度计算不能使用。

2.2 预定义字符型

c–一般字符类型,长度为1到262143个字符。

string–用于存储数据字典中的字符串和短字符串(string和SSSTRING)的类型,以及广泛的字符串操作。

n–数据字典中NUMC类型的模拟

d–用于存储数据字典中的DATS值的日期类型,即yyyymmdd。长度为8个字符。应用日期验证规则:“yyyy”(年)应在0001到9999之间,“mm”(月)应在01到12之间,“dd”(日)应在1到31之间。

t–用于存储数据字典中的TIMS值的时间类型,即hhmmss。长度为6个字符。应用时间验证规则:“hh”(小时)应在00到23之间,“mm”(分钟)应在0到59之间,“ss”(秒)应在00到59之间。

使用类似字符的预定义类型时,应始终考虑Unicode系统。UTF16代码页有两个字节长的字符。动态对象的最大大小也适用于DDIC字符类型。CL_ABAP_ELEMDESCR类可用于检查类型n和c的最大长度。

2.3 预定义字节型

预定义的ABAP类型用于存储和操作ABAP程序中的字节链,以及与数据字典类型RAW、LRAW和RAWSRING的交互。

x–长度为1至524287字节的字节链。模拟RAW DDIC类型。

xstring–可变长度的字节链。RAWSRING DDIC类型的模拟。

与以前的可变长度类型一样,xstring的最大长度不是无限的。它取决于当前系统上的内存配置,可以通过CL_ABAP_ELEMDESCR类常量TYPE_X_MAX_LENGTH进行检查。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SAP ABAP,COLLECT是一个用于聚合相同记录的语句。它将相同的行合并为一个,并将非关键字段的值相加。 COLLECT语句的基本语法如下: ``` COLLECT <itab> INTO <wa> [WITH <key>] ``` 其,`<itab>`是输入内表,`<wa>`是输出工作区,`<key>`是可选的关键字,指定要聚合的字段。 以下是一些使用COLLECT语句的示例: 1. 将相同的销售订单行项目合并为一个,并将数量相加: ``` TYPES: BEGIN OF ty_sales, orderid TYPE vbak-vbeln, item TYPE vbap-posnr, qty TYPE vbap-erfmg, END OF ty_sales. DATA: lt_sales TYPE TABLE OF ty_sales, ls_sales TYPE ty_sales, lt_result TYPE TABLE OF ty_sales. SELECT vbeln posnr erfmg FROM vbap INTO CORRESPONDING FIELDS OF TABLE lt_sales. LOOP AT lt_sales INTO ls_sales. COLLECT ls_sales INTO ls_sales GROUP BY ( orderid = ls_sales-orderid item = ls_sales-item ) WITH SUMMATION qty. ENDLOOP. SORT lt_sales BY orderid item. APPEND LINES OF lt_sales TO lt_result. ``` 2. 将相同的部门名称合并为一个,并计算员工数量和平均工资: ``` TYPES: BEGIN OF ty_employee, name TYPE string, dept TYPE string, salary TYPE p, hiredate TYPE d, END OF ty_employee. DATA: lt_employee TYPE TABLE OF ty_employee, ls_employee TYPE ty_employee, lt_result TYPE TABLE OF ty_employee. SELECT name dept salary hiredate FROM employee INTO CORRESPONDING FIELDS OF TABLE lt_employee. LOOP AT lt_employee INTO ls_employee. COLLECT ls_employee INTO ls_employee GROUP BY dept WITH SUMMATION salary AND COUNT name. ENDLOOP. SORT lt_employee BY dept. APPEND LINES OF lt_employee TO lt_result. ``` 在这些示例,我们使用COLLECT语句将相同的记录合并为一个,并计算非关键字段的总和或平均值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiaomici

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值