Basic SAP Data Types
Basic SAP Data Types
The parameter types that the Microsoft BizTalk Adapter 3.0 for mySAP Business Suite supports are governed by the:
- ABAP data types that SAP supports
- Database data types that SAP supports
This section presents a mapping between the ABAP and database data types, and their corresponding .NET and XML schema types.
Note |
|---|
| The information in this section applies to RFCs, tRFCs, and BAPIs. SAP data types are always represented as strings (xsd:string) in IDOCs. This is to support the BizTalk Server flat file parser. |
The Microsoft BizTalk Adapter 3.0 for mySAP Business Suite supports safe typing for some ABAP data types. When safe typing is enabled, these data types are represented as strings. You configure safe typing by setting the EnableSafeTyping binding property. Safe typing is disabled by default. For more information about the SAP adapter binding properties, see Working with BizTalk Adapter 3.0 for mySAP Business Suite Binding Properties.
The following table shows how the ABAP data types are surfaced when safe typing is not enabled. (EnableSafeTyping is false). Data types that are surfaced differently when safe typing is enabled are marked with an asterisk (*).
| ABAP Data Type | RFC Type | XSD type | .NET type | Format string |
|---|---|---|---|---|
|
I (Integer) |
RFC_INT |
xsd:int |
Int32 |
- |
|
Internal (RFC_INT1) |
RFC_INT1 |
xsd:unsignedByte |
Byte |
- |
|
Internal (RFC_INT2) |
RFC_INT2 |
xsd:short |
Int16 |
- |
|
F (Float) |
RFC_FLOAT |
xsd:double |
Double |
- |
|
P (BCD number) |
RFC_BCD |
xsd:decimal if length <= 28 |
Decimal |
Decimal number. with 0 decimal places |
|
C (Character) |
RFC_CHAR |
xsd:string |
String |
- |
|
D (Date: YYYYMMDD)* |
RFC_DATE |
xsd:dateTime |
DateTime |
Internally, the adapter deserializes the value into a DateTime object. It then invokes theDateTime.ToUniversalTime method to convert the value of this object to UTC. Finally the date component (DateTime.Date) is used to create the value that is sent to the SAP system. The SAP system treats this date value as local time. You should specify date values as UTC to avoid conversion.
|
|
T (Time: HHMMSS)* |
RFC_TIME |
xsd:dateTime |
DateTime |
Internally, the adapter deserializes the value into a DateTime object. It then invokes theDateTime.ToUniversalTime method to convert the value of this object to UTC. Finally the time component (DateTime.Time) is used to create the value that is sent to the SAP system. The SAP system treats this time value as local time. You should specify time values as UTC to avoid conversion.
For example, if your local time is 9:15 am, express this as "(001-01-01)T(09:15:00)Z" |
|
N (Numeric string)* |
RFC_NUM |
xsd:int if lenrth <= 9 |
Int32 |
- |
|
X (Byte) |
RFC_BYTE |
xsd:base64Binary |
Byte[] |
- |
|
STRING |
RFC_STRING |
xsd:string |
String |
- |
|
XSTRING |
RFC_BYTE |
xsd:base64Binary |
Byte[] |
- |
*Indicates that the data type is surfaced differently when safe typing is enabled.
Safe Typing Enabled
The following table shows the ABAP data types that are surfaced differently when safe typing is enabled (the EnableSafeTyping binding property is true).
| ABAP Data Type | RFC Type | XSD type | .NET type | Format string |
|---|---|---|---|---|
|
D (Date: YYYYMMDD) |
RFC_DATE |
xsd:string |
String |
SAP date format: YYYYMMDD. Characters are allowed for date digits, so the value is essentially an eight character string |
|
T (Time: HHMMSS) |
RFC_TIME |
xsd:string |
String |
SAP time format: HHMMSS. Characters are allowed for time digits, so the value is essentially a six character string |
|
N (Numeric string) |
RFC_NUM |
xsd:string |
String |
An n character string; where n = length of the numc field. |
ABAP data types that are not in this table are surfaced in the same way as when safe typing is not enabled.
Support for Date and Time Fields
When safe typing is not enabled, ABAP Date (D) and Time (T) types are surfaced as xsd:dateTime; however, the pattern facet surfaced for the Date and Time types is different.
- The pattern facet for Date is:
(\d\d\d\d-\d\d-\d\d)T(00:00:00)(.*)For example, July 7, 2007 (2007-07-07) is represented as:
(2007-07-07)T(00:00:00). - The pattern facet for Time is:
(0001-01-01)T(\d\d:\d\d:\d\d)(.*)For example, 18:30:30 (6:30 pm and 30 seconds) is represented as:
(0001-01-01)T(18:30:30).
How does the Adapter Represent Minimum and Maximum Time Values on Inbound Messages (from SAP)?
The SAP adapter uses the following guidelines when it receives time values from the SAP system:
- The adapter treats 000000 (hhmmss) and 240000 (hhmmss) as 0 hours, 0 mins, and 0 seconds.
The way in which the Microsoft BizTalk Adapter 3.0 for mySAP Business Suite surfaces database data types also depends on whether safe typing is enabled. The following table shows how the adapter surfaces database data types when safe typing is not enabled (the EnableSafeTyping binding property is false). Data types that are surfaced differently when safe typing is enabled are marked with an asterisk (*).
| Database Data Type | RFC Type | XSD | .NET Type |
|---|---|---|---|
|
ACCP (Posting Period)* |
RFC_NUM |
xsd:int |
Int32 |
|
CHAR |
RFC_CHAR |
xsd:string |
String |
|
CLNT (Client) |
RFC_CHAR |
xsd:string |
String |
|
CURR (Currency field) |
RFC_BCD |
xsd:decimal NoteThe SAP adapter rounds off the decimal values based on the definition of the DECIMAL parameter. For example, if a DECIMAL parameter can accept up to five digits after the decimal point, a value such as 4.000028 is rounded off to 4.00003.
|
Decimal |
|
CUKY (Currency Key) |
RFC_CHAR |
xsd:string |
String |
|
DATS (Date field)* |
RFC_DATE |
xsd:dateTime Internally, the adapter deserializes the value into a DateTime object. It then invokes theDateTime.ToUniversalTime method to convert the value of this object to UTC. Finally the date component (DateTime.Date) is used to create the value that is sent to the SAP system. The SAP system treats this date value as local time. You should specify date values as UTC to avoid conversion. The following pattern is recommended: "(\d\d\d\d-\d\d-\d\d)T(00:00:00)(.*)Z". |
DateTime You should specify date values as UTC (DateTime.Kind = DateTimeKind.Utc) to avoid conversion. |
|
DEC (Amount) |
RFC_BCD |
xsd:decimal NoteThe SAP adapter rounds off the decimal values based on the definition of the DECIMAL parameter. For example, if a DECIMAL parameter can accept up to five digits after the decimal point, a value such as 4.000028 is rounded off to 4.00003.
|
Decimal |
|
FLTP (Floating point) |
RFC_FLOAT |
xsd:double |
Double |
|
INT1 |
RFC_INT1 |
xsd:unsignedbyte |
Byte |
|
INT2 |
RFC_INT2 |
xsd:short |
Int16 |
|
INT4 |
RFC_INT |
xsd:int |
Int32 |
|
LANG (Language Key) |
RFC_CHAR |
xsd:string |
String |
|
LCHR |
RFC_STRING |
xsd:string |
String |
|
LRAW (long byte seq) |
RFC_BYTE |
xsd:base64binary |
Byte[] |
|
NUMC* |
RFC_NUM |
xsd:int |
Int32 if length <=9 |
|
PREC (Accuracy) |
RFC_INT2 |
xsd:short |
Int16 |
|
QUAN (Quantity) |
RFC_BCD |
xsd:decimal NoteThe SAP adapter rounds off the decimal values based on the definition of the DECIMAL parameter. For example, if a DECIMAL parameter can accept up to five digits after the decimal point, a value such as 4.000028 is rounded off to 4.00003.
|
Decimal |
|
RAW (byte sequence) |
RFC_BYTE |
xsd:base64binary |
Byte[] |
|
RAWSTRING (variable length) |
RFC_BYTE |
xsd:base64binary |
Byte[] |
|
STRING (variable length) |
RFC_STRING |
xsd:string |
String |
|
TIMS (Time field)* |
RFC_TIME |
xsd:datetime Internally, the adapter deserializes the value into a DateTime object. It then invokes theDateTime.ToUniversalTime method to convert the value of this object to UTC. Finally the time component (DateTime.Time) is used to create the value that is sent to the SAP system. The SAP system treats this time value as local time. You should specify time values as UTC to avoid conversion. The following pattern is recommended: "(0001-01-01)T(\d\d:\d\d:\d\d)(.*)Z". For example, if your local time is 9:15 am, express this as "(001-01-01)T(09:15:00)Z" |
DateTime You should specify time values as UTC (DateTime.Kind = DateTimeKind.Utc) to avoid conversion. |
|
UNIT (Unit for Qty) |
RFC_CHAR |
xsd:string |
String |
|
[Unsupported] |
-- |
-- |
String |
*Indicates that the adapter surfaces the data type differently when safe typing is enabled.
Safe Typing Enabled
The following table shows the database data types that are surfaced differently when safe typing is enabled (the EnableSafeTyping binding property is true).
| Database Data Type | RFC Type | XSD | .NET type | String Value Format |
|---|---|---|---|---|
|
ACCP (Posting Period) |
RFC_NUM |
xsd:string |
String |
Character string |
|
NUMC |
RFC_NUM |
xsd:string |
String |
Character string |
|
DATS (Date field) |
RFC_DATE |
xsd:string |
String |
YYYYMMDD |
|
TIMS (Time field) |
RFC_TIME |
xsd:string |
String |
HHMMSS |
Data types that are not in this table are surfaced in the same way as when safe typing is not enabled.
The SAP adapter supports the following XSD facets.
| RFC Type | XSD Facet (EnableSafeTyping = false) | XSD Facet (EnableSafeTyping = true) |
|---|---|---|
|
RFC_BCD |
XSD pattern facet Zero decimal places: One or more decimal places: |
same |
|
RFC_NUM |
XSD totalDigits facet if length <=19 XSD pattern facet if length > 19 |
XSD maxLength facet (depends on the length of the value on SAP) |
|
RFC_DATE |
XSD pattern facet
Pattern contains time 00:00:00 to be compatible with |
XSD maxLength facet = 8 |
|
RFC_TIME |
XSD pattern facet
Pattern contains date 0001-01-01 to be compatible with |
XSD maxLength facet = 6 |
|
RFC_CHAR |
XSD maxLength facet |
same |
Basic SAP Data Types的更多相关文章
- Core Java Volume I — 3.3. Data Types
3.3. Data TypesJava is a strongly typed language(强类型语音). This means that every variable must have a ...
- 【12c】扩展数据类型(Extended Data Types)-- MAX_STRING_SIZE
[12c]扩展数据类型(Extended Data Types)-- MAX_STRING_SIZE 在12c中,与早期版本相比,诸如VARCHAR2, NAVARCHAR2以及 RAW这些数据类型的 ...
- Oracle Schema Objects——Tables——Oracle Data Types
Oracle Schema Objects Oracle Data Types 数据类型 Data Type Description NUMBER(P,S) Number value having a ...
- C and SQL data types for ODBC and CLI
C and SQL data types for ODBC and CLI This topic lists the C and SQL data types for ODBC and CLI a ...
- allow zero datetime=true导致datetime转换失败:MySql.Data.Types.MySqlDateTime”的对象无法转换为类型“System.Nullable`1[System.DateTime]
allow zero datetime=true导致datetime转换失败:MySql.Data.Types.MySqlDateTime”的对象无法转换为类型“System.Nullable`1[S ...
- "SQL Server does not handle comparison of NText, Text, Xml, or Image data types."
"SQL Server does not handle comparison of NText, Text, Xml, or Image data types." sql2000 ...
- ExtJS笔记 Ext.data.Types
This is a static class containing the system-supplied data types which may be given to a Field. Type ...
- Entity Framework Code First (七)空间数据类型 Spatial Data Types
声明:本文针对 EF5+, Visual Studio 2012+ 空间数据类型(Spatial Data Types)是在 EF5 中引入的,空间数据类型表现有两种: Geography (地理学上 ...
- Delphi Data Types
http://docwiki.embarcadero.com/RADStudio/XE6/en/Delphi_Data_Types Integer Data Types Type Descriptio ...
随机推荐
- Flutter中打造多行列列表GridView组件的使用
GridView组件.一个可滚动的二维空间数组. 在使用无限加载滚动列表的时候,最先使用的还是ListView组件.但若是要一行显示2列或者更多列的滚动列表,GridView组件更为方便.如下 在向服 ...
- webpack的版本进化史
一.概述2015,webpack1支持CMD和AMD,同时拥有丰富的plugin和loader,webpack逐渐得到广泛应用. 2016.12,webpack2相对于webpack1最大的改进就是支 ...
- BZOJ.1190.[HNOI2007]梦幻岛宝珠(分层背包DP)
题目链接 把重量表示为\(a\times2^b\)的形式,然后按\(b\)排序. 从高到低枚举每一位,\(f[i]\)表示当前位容量为\(i\)时的最大价值(容量即\(a\times2^{bit}\) ...
- 洛谷P2982 [USACO10FEB]慢下来Slowing down(线段树 DFS序 区间增减 单点查询)
To 洛谷.2982 慢下来Slowing down 题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) cows con ...
- treap(树堆)
一棵treap是一棵修改了结点顺序的二叉查找树,如图,显示一个例子,通常树内的每个结点x都有一个关键字值key[x],另外,还要为结点分配priority[x],它是一个独立选取的随机数. 假设所有的 ...
- php中对Mysql数据库的访问操作
一: PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extensio ...
- 【原创】python模拟腾讯网页登录
近日,研究Tencent网页模拟登录的过程,过程有些忐忑,但最终还是实现了这一功能.先将结果写于此,供大家参考: 其加密过程在c_login_old.js文件中执行,将JS关键代码提取出来如下: fu ...
- Hbase常用Shell命令
status 查看系统状态 hbase(main):010:0> status 1 active master, 0 backup masters, 4 servers, 0 dead, 6.5 ...
- 详解Paint的setColorFilter(ColorFilter filter)
一.简介 setColorFilter(ColorFilter filter) 设置颜色过滤,这个方法需要我们传入一个ColorFilter参数同样也会返回一个ColorFilter实例.我们在set ...
- 浅谈压缩感知(十九):MP、OMP与施密特正交化
关于MP.OMP的相关算法与收敛证明,可以参考:http://www.cnblogs.com/AndyJee/p/5047174.html,这里仅简单陈述算法流程及二者的不同之处. 主要内容: MP的 ...
Note