Basic SAP Data Types

6 out of 11 rated this helpful - Rate this topic

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
xsd:string if length > 28

Decimal
String

Decimal number. with 0 decimal places
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.

  • For xsd:dateTime, the following pattern is recommended: "(\d\d\d\d-\d\d-\d\d)T(00:00:00)(.*)Z".
  • For DateTime objects set DateTime.Kind to DateTimeKind.Utc.

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 xsd:dateTime, the following pattern is recommended: "(0001-01-01)T(\d\d:\d\d:\d\d)(.*)".
  • For DateTime objects set DateTime.Kind to DateTimeKind.Utc.

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
xsd:long if length > 9 and <= 19
xsd:string if length > 19

Int32
long
String

-

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

Note
The 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

Note
The 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
xsd:long
xsd:string

Int32 if length <=9
Int64 if length >9 and <=19
String if length > 19

PREC (Accuracy)

RFC_INT2

xsd:short

Int16

QUAN (Quantity)

RFC_BCD

xsd:decimal

Note
The 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: "([\\-]{0,1})(([0-9]{1," + digitsBeforeDecimal + "}))"

One or more decimal places: "([\\-]{0,1})(([0-9]{0," + digitsBeforeDecimal + "}\\.[0-9]{0," + digitsAfterDecimal + "})|([0-9]{1," + digitsBeforeDecimal + "}))"

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

"(\d\d\d\d-\d\d-\d\d)T(00:00:00)(.*)"

Pattern contains time 00:00:00 to be compatible with xsd:datetime

XSD maxLength facet = 8

RFC_TIME

XSD pattern facet

"(0001-01-01)T(\d\d:\d\d:\d\d)(.*)"

Pattern contains date 0001-01-01 to be compatible with xsd:datetime

XSD maxLength facet = 6

RFC_CHAR

XSD maxLength facet

same

Basic SAP Data Types的更多相关文章

  1. 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 ...

  2. 【12c】扩展数据类型(Extended Data Types)-- MAX_STRING_SIZE

    [12c]扩展数据类型(Extended Data Types)-- MAX_STRING_SIZE 在12c中,与早期版本相比,诸如VARCHAR2, NAVARCHAR2以及 RAW这些数据类型的 ...

  3. Oracle Schema Objects——Tables——Oracle Data Types

    Oracle Schema Objects Oracle Data Types 数据类型 Data Type Description NUMBER(P,S) Number value having a ...

  4. 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 ...

  5. 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 ...

  6. "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 ...

  7. ExtJS笔记 Ext.data.Types

    This is a static class containing the system-supplied data types which may be given to a Field. Type ...

  8. Entity Framework Code First (七)空间数据类型 Spatial Data Types

    声明:本文针对 EF5+, Visual Studio 2012+ 空间数据类型(Spatial Data Types)是在 EF5 中引入的,空间数据类型表现有两种: Geography (地理学上 ...

  9. Delphi Data Types

    http://docwiki.embarcadero.com/RADStudio/XE6/en/Delphi_Data_Types Integer Data Types Type Descriptio ...

随机推荐

  1. HDU 2048 神、上帝以及老天爷 【递推】【错排】

    题目链接 Problem Description HDU 2006'10 ACM contest的颁奖晚会隆重开始了!为了活跃气氛,组织者举行了一个别开生面.奖品丰厚的抽奖活动,这个活动的具体要求是这 ...

  2. spring整合ssmXML版

    以下是一个简单的ssm项目:如果中途报错,肯定是tomcat配置或者数据库配置有问题,在程序中注意将包名等配置换成自己的.数据库表需要提前建好,并加入数据,注意表结构要和实体对象对应. 1.开发条件: ...

  3. go语言学习-基础知识

    go程序的基本结构 一个可以最简单的可运行的go程序需要满足下面两个条件: 有一个main()函数 main()函数在main包中 例如: 在go语言中的 hello world 程序如下: // m ...

  4. 如何通过<include/>标签重用Mybatis的代码段

    1.首先定义一个sql标签,一定要定义唯一id<sql id="Base_Column_List" >name,age</sql>2.然后通过id引用< ...

  5. 电商sku商品推荐

    1.逻辑回归LR进行实时离线三级品类训练. 2.通过用户对于实时.离线三级品类的偏好进行召回. 3.通过人的特征.sku特征.人sku交互特征.以及位置手机特征通过gbdt模型进行点击量预估.

  6. [HihoCoder1393]网络流三·二分图多重匹配

    题目大意: 班级有$N$名学生,运动会有$M$项不同的比赛,第$i$项比赛每个班需要派出$m_i$名选手参加,编号为i的学生最多同时参加给定的$b_i$项比赛中的任意$a_i$项比赛.根据统计的结果, ...

  7. 【NOIP2014模拟赛No.1】我要的幸福

    OJ题号:ZHOJ1297 思路:搜索. 先预处理注定不能走的路径,然后dfs可以走的路径. #pragma GCC optimize ("O2") #include<cst ...

  8. [BOI2004]Sequence 数字序列

    Description: Hint: \(n<=10^5\) Solution: 首先考虑b不严格递增时的做法 发现当\(a[i]\)递增时\(b[i]\)直接取\(a[i]\)即可,否则此时需 ...

  9. window + php + memcached 安装

    第一步:安装windows版memcached 下载地址:http://download.csdn.net/detail/zhaotengfei36520/8182503#comment 下载之后将文 ...

  10. weblogic10 部署 spring+cxf ,调用时报:cannot create a secure XmlInputFactory

    weblogic10 部署 spring+cxf ,调用时报:cannot create a secure XmlInputFactory   一个cxf webservice项目部署到tomcat能 ...