SAP HANA SQL Command Network Protocol Reference en
SAP HANA SQL Command Network Protocol Reference en
1 Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.1 Terminology. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.2 Protocol Modification. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2 Message Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.1 Message Header. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7
2.2 Segment Header. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
Segment Kind. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Message Type. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .9
Command Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10
Function Code. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.3 Part Header. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Part Kind. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Part Attributes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14
2.4 Use of Parts in Request Messages. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
2.5 Use of Parts in Reply Messages. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
2.6 Type Codes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.7 Part Data Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Option Part Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Multi-Line Option Part Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
COMMAND. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
RESULTSET. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
ERROR. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
STATEMENTID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
TRANSACTIONID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
ROWSAFFECTED. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
RESULTSETID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .24
TOPOLOGYINFORMATION. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .24
TABLELOCATION. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
READLOBREQUEST. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
READLOBREPLY. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
ABAPISTREAM. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
ABAPOSTREAM. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
COMMANDINFO. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
WRITELOBREQUEST. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
WRITELOBREPLY. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
PARAMETERS. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .29
3 Glossary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
This document describes the SQL Command Network Protocol of the SAP HANA database, the protocol used
by SAP HANA database clients to communicate with the SAP HANA database.
Content Overview
This chapter describes the binary message format used in the communication, and explains the purpose of the
various protocol elements.
This chapter discusses usage scenarios for the various messages defined in the SQL Command Network
Protocol, and defines usage sequences to utilize certain functionalities of the database server, such as:
1.1 Terminology
A message describes requests or replies exchanged between client and server. A request is always a message
sent by the client, and a reply is always the message sent by the server.
The following abbreviations are used to describe data types in message formats:
Table 1:
Abbreviation Data Type C Data Type1
NUI8 8-byte unsigned integer in client native (big/little-endian) format unsigned long
FLOAT IEEE single precision floating point value in little-endian format float
DOUBLE IEEE double precision floating point value in little-endian format double
Additions to the protocol require careful modification and extension of the exchanged connect options.
The SQL Command Network Protocol must be kept stable so that clients are able to communicate with recent
version server software, and vice versa. A more recent client may have to degrade the usage of the protocol
depending on the server version, and a more recent server may have to use only certain features if non-recent
client software is detected.
Detection is performed during connection by exchanging connect options, which specify the required behavior
of the client, and getting the supported feature set from the server. This detection does not perform global
versioning, but enables or disables feature flags, or modifies certain functionality.
This chapter discusses the format of messages exchanged between the client and the server.
The communication between client and server is completely synchronous, such that the client can only send
the next request once the reply of the previous request has been fully received. A client is, however, free to
continue with its own processing, or communicate with other servers of a SAP HANA database system while
waiting for the answer.
A message consists of a fixed part, called the message header, and a variable length message buffer. The
message buffer contains message segments, which, in turn, consist of a segment header and a segment
buffer. The segment buffer contains parts, and the parts have a fixed length part header, and a variable
length buffer.
There is one exception to this format during the communication initialization a different message pair is
exchanged, which is necessary to distinguish the current and former protocol variants.
The message header is a structure which has a size of 32-bytes, and consists of the following fields:
Table 2:
Field Data Type Description
PACKETCOUNT I4 Packet sequence number in this session. Packets having the same sequence
number belong to one request/response pair.
The segment header has a length of 24-bytes. There are different segment header structures for request and
reply, but both have the same definition for first 13-bytes of the structure. They are structured as follows:
Table 3:
Field Data Type Description
Related Information
The segment kind field is the last field of the segment header part, common to all types (kinds) of segments,
and defines the segment kind, which further specifies the layout of the remaining segment header structure.
Table 4:
Value Description
1 Request segment
2 Reply segment
The message type defines the action requested from the database server.
Table 5:
Value Identifier Description
72 FETCHABSOLUTE Moves the cursor to the given row number and fetches the data.
73 FETCHRELATIVE Moves the cursor a number of rows relative to the position, either positive or
negative, and fetches the data.
74 FETCHFIRST Moves the cursor to the first row and fetches the data.
75 FETCHLAST Moves the cursor to the last row and fetches the data.
79 FETCHNEXTITAB Fetches next data for ITAB object in Fast Data Access mode
80 INSERTNEXTITAB Inserts next data for ITAB object in Fast Data Access mode
The command options field is a bit set that allows specific options for the sent message to be defined.
Table 6:
Bit Identifier Description
3 HOLD_CURSORS_OVER_COMMIT Keeps result set created by this command over commit time
The function code identifies the nature of the statement or functionality that has been prepared or executed.
Table 7:
Value Identifier Description
Table 8:
Field Data Description
Type
PARTKIND I1 Specifies nature of part data. For more information about part kind, see Re
lated Information.
PARTATTRIBUTES I1 Further attributes of part. For more information about part attributes, see
Related Information.
BIGARGUMENTCOUNT I4 Argument count, number of elements in part data (only for some part kinds)
Related Information
The part kind field is the first section of the part header.
Table 9:
Value Identifier Description
The part attributes make up a bit set to indicate special features of a certain part.
Table 10:
Bit Identifier Description
The following table shows the parts that can be used in various request message types. The letter X denotes
the default relationship between the part and message. Any letters other than X denote a conditional
relationship, which are described in further detail below the table.
B Only in the case that the prepared statement has input parameters
The following table shows the parts that can be used in various reply message types. The letter X denotes the
default relationship between the part and message. Any letters other than X denote a conditional relationship,
which are described in further detail below the table.
C Only in the case that the statement generates a row count of affected rows
D Always if the statement caused an action in transaction handling (commit, rollback, or start of a new write
transaction)
E Only in the case that the server has information useful to applying statement routing (see the
corresponding Usage Scenario Statement Routing)
F Only in the case that the statement has input and/or output parameters
Type codes identify the type of a field transferred from or to the database. Not all type codes known and
processed internally are used in the protocol, and clients may support a different level of type support
depending on their version. The protocol mechanism (connect options) for connecting to the database is used
to ensure that the client sends the server data it is able to process, and receives only data it can process from
the server.
Type codes are in the range of 0-127, as the most significant bit is used on input to signal a NULL value of a
certain type.
Table 11:
Value Identifier Description Support Level
1 TINYINT TINYINT 1
2 SMALLINT SMALLINT 1
3 INT INTEGER 1
4 BIGINT BIGINT 1
6 REAL REAL 1
7 DOUBLE DOUBLE 1
8 CHAR CHAR 1
9 VARCHAR VARCHAR 1
12 BINARY BINARY 1
35 VARCHAR2 VARCHAR -
36 VARCHAR3 VARCHAR -
37 NVARCHAR3 NVARCHAR -
38 VARBINARY3 VARBINARY -
This section describes the format of parts transmitted in messages between the client and the database
server.
The format of the data transmitted is uniquely identified by the part kind, some part kinds share the same
format as the contained data.
The option part format is a common format to transmit options, that is, typed key-value pairs.
Table 12:
Field Data Type Description
Only some type codes are understood for the option type field, and the data format of the option data is as
follows:
Table 13:
Type Code Value Format
STRING 2-byte signed integer (short ) length information, little-endian format, followed by the string in
CESU-8 encoding (number of bytes is specified by length information)
BSTRING 2-byte signed integer (short ) length information, little-endian format, followed by the binary
string (number of bytes is specified by length information)
The multi-line option part format is a common format to transmit collections of options (typed key-value
pairs).
An option part contains rows having the following structure. The number of rows is the part argument count
value.
Table 14:
Field Data Type Description
Different rows can have a different argument count, so the format is not completely tabular.
2.7.3 COMMAND
The COMMAND part contains the text of an SQL command. The text is always encoded in CESU-8 encoding.
2.7.4 RESULTSET
The fields of the individual rows are formatted as defined in the output field format section. One result set part
contains as many rows as the argument count field indicates:
Note that the field values may have variable lengths, depending on the data type. Therefore, all the values in
the current row must be scanned before moving to the next row.
2.7.5 ERROR
An ERROR part contains one or more errors returned by the database server to the client. The error part
contains elements having the following structure:
Table 15:
Field Data Type Description
SQLSTATE B[5] SQLSTATE as defined by the SQL standard for this message
The error level defines the level of the message warning, error, or fatal session-terminating error -- using the
following values:
Table 16:
Value Identifier Description
1 ERROR Error message, this statement (or part of it) has failed
2.7.6 STATEMENTID
A STATEMENTID part contains a statement identifier, which is a byte array of 8-bytes in length. The statement
identifier is opaque to the client program.
2.7.7 TRANSACTIONID
A TRANSACTIONID part contains the identifier of a transaction, which is a byte array of variable length, and
stored in the same way as a VARBINARY output value. The transaction identifier is opaque to the client
program.
2.7.8 ROWSAFFECTED
A ROWSAFFECTED part contains one or multiple (as many as the parts ARGUMENTCOUNT field defines) 32-
bit integers, which indicate the number of rows affected by a statement, or a row of an array command.
Table 17:
Value Identifier Description
-2 SUCCESS_NO_INFO Statement/row has been processed but number of affected rows cannot be
determined.
2.7.9 RESULTSETID
A RESULTSETID part contains the identifier of a result set, which is a byte array of 8-bytes in length. The result
set identifier is opaque to the client program.
2.7.10 TOPOLOGYINFORMATION
Table 18:
Value Identifier Data Type Description
B Externally-visible IP address/name in SAP HANA SPS 06, internal host name in previous SAP HANA
revisions
HOSTNAME
This field contains the host name of the server, without any domain part, for SAP HANA revisions before SPS
06.
Beginning with SAP HANA SPS 06, this is the externally visible TCP/IP address of the server.
HOSTPORTNUMBER
This field contains the port number of the SQL port of the server.
TENANTNAME
LOADFACTOR
This field contains a factor used when distributing workload among servers. A load factor of 1.0 is the default
value.
VOLUMEID
This field contains the volume ID of the data volume managed by this server, or 0 if there is no data volume
attached yet (as in case with a standby server).
ISMASTER
This field contains a 1 (true), if the server is the master server of the SAP HANA database system.
ISCURRENTSESSION
This field contains a 1 (true), if the server that manages the session has returned this topology information.
This field contains the network domain of the server, if a non-empty domain is defined. Beginning with SAP
HANA SPS 06, this field is not sent to the client.
ISSTANDBY
ALLIPADDRESSES
This field contains a comma-separated list of the TCP/IP addresses assigned to this node. Beginning with SAP
HANA SPS 06, this field is not sent to the client.
ALLHOSTNAMES
This field contains a comma-separated list of all host names assigned to this node. Beginning with SAP HANA
SPS 06, this field is not sent to the client.
2.7.11 TABLELOCATION
A table location part contains one or multiple 4-byte integers in little-endian format, which identify the data
volume IDs.
The number of elements is the argument count of the part. The returned volume IDs signal preferred execution
locations for the statement, and depend on the:
Nature of the SQL command that is prepared (some commands can only be executed on a certain server)
Number of partitions of the tables affected by the statement
Location of the tables affected by the statement
2.7.12 READLOBREQUEST
A read LOB request part is sent by the client to request BLOB/CLOB/NCLOB data to be read.
Table 19:
Field Data Type Description
For byte-based large object types, the READOFFSET and READLENGTH define byte positions and length
values, for character-based large object types, these fields define character positions and length values within
the large object.
2.7.13 READLOBREPLY
The READLOBREPLY part is sent from the database as answer to a read LOB request of the client.
Table 20:
Field Data Type Description
The OPTIONS field is a bit set which has the following defined values:
Table 21:
Bit Identifier Description
0 NULLINDICATOR The large object value is NULL (not used for READLOBREPLY).
An ABAPISTREAM part is sent from the database requesting an ABAP input stream for C++ procedure
processing, and as a response from the client when sending the stream data.
Table 22:
Field Data Type Description
MASK B[] Bit field to mask entries of the ABAP table do not transfer them
The MASK field may be omitted completely. In this case, all columns of the ABAP table are transferred.
Otherwise, only the marked values are transferred, enabling a projection of the ABAP table in the server
processing. The number of rows requested is supplied in the argument count of the ABAPISTREAM part. In the
case that the client sends this part to identify stream data transmitted to the database server, only the
ABAPTABID field is used.
2.7.15 ABAPOSTREAM
The ABAPOSTREAM part contains one 4-byte integer value identifying the ABAPTABID of the table, whose
data is sent in the corresponding STREAMDATA part.
2.7.16 COMMANDINFO
Table 23:
Value Identifier Data Type Description
This part is used to identify the location of a statement in the source program for debugging and analysis
purposes.
The WRITELOBREQUEST part is sent from the client to write data piece-wise into a large object.
Table 24:
Field Data Type Description
A number of large objects may be written using this request. The argument count of the part describes how
many elements are contained in the part.
The OPTIONS field is a bit set which has the following defined values:
Table 25:
Bit Identifier Description
0 NULLINDICATOR The large object value is NULL (not used for WRITELOBREQUEST).
2.7.18 WRITELOBREPLY
The WRITELOBREPLY part is sent as reply from the server to a WRITELOBREQUEST part.
It contains the LOCATORID identifiers for all large object locators which can still receive data (if LASTDATA
has not been set). The argument count defines the number of locator identifiers contained in the data.
2.7.19 PARAMETERS
The parameters are densely packed, and use the input field format. The argument count of the part defines
how many rows of parameters are included.
2.7.20 AUTHENTICATION
Table 26:
Field Data Type Description
Table 27:
Field Data Type Description
Table 28:
Field Data Type Description
Initial Request
The initial request contains the database user name, and field pairs (method name/value) for each
authentication method requested by the client.
Table 29:
Method Name Description
Additional Requests
Requests, following the initial request, contain a number of field pairs for authentication methods, which are
performed by exchanging messages.
2.7.21 SESSIONCONTEXT
Table 30:
Value Identifier Data Type Description
The primary connection is the first connection opened by the client program to the system in a distributed
scenario. The master connection is the connection that started the current distributed transaction.
2.7.22 STATEMENTCONTEXT
Table 31:
Value Identifier Data Type Description
This part is populated from previously received statement context information. The binary option content is
opaque to the client application.
2.7.23 PARTITIONINFORMATION
The PARTITIONINFORMATION part is returned by the server to allow a more specific pruning of input data, as
it pertains to the partitioning of data in the database server.
Table 32:
Field Data Type Description
Table 33:
Value Identifier Description
The PARAMETERS field contains NUMPARAMETERS elements having the following structure:
Table 34:
Field Data Type Description
Table 35:
Value Identifier Description
Table 36:
Value Identifier Description SQL Data Type2
86 TEXT SHORTTEXT
2 This reflects the default mapping of SQL data types to column store types.
68 DATE
116 TIME
84 TEXT_OLD
69 UNITDECFLOAT
77 DECIMAL_FLOAT
76 SDFLOAT
2.7.24 OUTPUTPARAMETERS
The format of the OUTPUTPARAMETERS part is the same as the format of the RESULTSET part.
The part contains the scalar output parameter values returned by the statement.3 The argument count is
always 1.
2.7.25 CONNECTOPTIONS
Table 37:
Value Identifier Data Type Description
EXECUTION
2 This reflects the default mapping of SQL data types to column store types.
3 An empty output parameter part can be sent if there are no scalar output parameters in the procedure definition, but non-
scalar output parameters (tables) instead.
BULKOPERATIONS
FORMATVERSION
VERSION
FLAGSONLY
OPTIMIZEDFORMAT
CONNECTIONID
This field contains the connection ID. It is filled by the server when the connection is established. This number
can be used in DISCONNECT/KILL commands for command or session cancellation.
COMPLETEARRAYEXECUTION
This field is set if array commands continue to process remaining input when detecting an error in an input
row. Always set for current client and server.
The session locale can be set by the client. The locale is used in language-dependent handling within the SAP
HANA database calculation engine.
SUPPORTSLARGEBULKOPERATIONS
LARGENUMBEROFPARAMETERSSUPPORT
This field contains the host name of the server, without any domain part. It is filled by the server with the host
name it resolves, so that it does not contain an alias name of the database server.
SYSTEMID
This option is set by the server and filled with the SAPSYSTEMNAME of the connected instance for tracing and
supportability purposes.
DATAFORMATVERSION2
The client indicates this set of understood type codes and field formats. The server then defines the value
according to its own capabilities, and sends it back. The following values are supported:
Table 38:
Value Description
3 Extended data type support: ALPHANUM, TEXT, SHORTTEXT, LONGDATE, SECONDDATE, DAYDATE,
SECONDTIME supported without translation. Deprecated, do not use
4 Support for ALPHANUM, TEXT, SHORTTEXT, LONGDATE, SECONDDATE, DAYDATE, and SECONDTIME.
Baseline data type support format for SAP HANA SPS 06.
ABAPVARCHARMODE
This field is set by the client to indicate that the connection should honor the ABAP character handling, that is:
SELECTFORUPDATESUPPORTED
This field is set by the client to indicate that the client is able to handle the special function code for SELECT
FOR UPDATE commands.
CLIENTDISTRIBUTIONMODE
This field is set by the client to indicate the mode for handling statement routing and client distribution. The
server sets this field to the appropriate support level depending on the client value and its own configuration.
The following values are supported:
Table 39:
Value Description
1 CONNECTION, client can connect to any (master/slave) server in the topology, and connections are ena
bled, such that the connection load on the nodes is balanced.
2 STATEMENT, server returns information about which node is preferred for executing the statement, cli
ents execute on that node, if possible.
ENGINEDATAFORMATVERSION
The server sets this field to the maximum version it is able to support. The possible values correspond to the
DATAFORMATVERSION flag.
DISTRIBUTIONPROTOCOLVERSION
This field is set by the client and indicates the support level in the protocol for distribution features. The server
may choose to disable distribution if the support level is not sufficient for the handling.
Table 40:
Value Description
0 Baseline version
1 Client handles statement sequence number information (statement context part handling).
CLIENTDISTRIBUTIONMODE is OFF if a value less than one (<1) is returned by the server.
SPLITBATCHCOMMANDS
This field is sent by the client and returned by the server if configuration allows splitting batch (array)
commands for parallel execution.
USETRANSACTIONFLAGSONLY
This field is sent by the server to indicate the client should gather the state of the current transaction only from
the TRANSACTIONFLAGS command, not from the nature of the command (DDL, UPDATE, and so on).
IGNOREUNKNOWNPARTS
This field is sent by the server to indicate it ignores unknown parts of the communication protocol instead of
raising a fatal error.
TABLEOUTPUTPARAMETER
This field is sent by the client to indicate that it understands output parameters described by type code TABLE
in result sets.
ITABPARAMETER
This field is sent by the server to signal it understands ABAP ITAB parameters of SQL statements (For-All-
Entries Optimization).
DESCRIBETABLEOUTPUTPARAMETER
This field is sent by the client to request that table output parameter metadata is included in the parameter
metadata of a CALL statement.4 The returned type of the table output parameter is either STRING or TABLE,
depending on the TABLEOUTPUTPARAMETER connect option.
Of course, more than one of these statements can be true for any option.
Table 41:
Option Client Pa Server Pa Version De
rameter rameter pendent
CONNECTIONID - - -
COMPLETEARRAYEXECUTION - - X
CLIENTLOCALE X - -
SUPPORTSLARGEBULKOPERATIONS - - X
LARGENUMBEROFPARAMETERSSUPPORT - X X
SYSTEMID - - -
DATAFORMATVERSION X - X
ABAPVARCHARMODE X - X
SELECTFORUPDATESUPPORTED - - X
CLIENTDISTRIBUTIONMODE X X X
ENGINEDATAFORMATVERSION - - X
DISTRIBUTIONPROTOCOLVERSION - - X
SPLITBATCHCOMMANDS X X X
USETRANSACTIONFLAGSONLY - - X
IGNOREUNKNOWNPARTS - - X
TABLEOUTPUTPARAMETER X - X
ITABPARAMETER - X X
DESCRIBETABLEOUTPUTPARAMETER X - X
4 This is the same behavior that can be achieved by setting the parameter
omit_table_output_parameter_metadata to false, except that by using the connect option, the setting is only
valid for the current session, not globally for the database instance.
Table 42:
Value Identifier Data Type Description
If HOLDCURSORSOVERCOMMIT is set by the client on commit, not only cursors marked explicitly as HOLD,
but all cursors, are held.5
2.7.27 FETCHOPTIONS
Table 43:
Value Identifier Data Type Description
The RESULTSETPOS field can be used to skip over entries when fetching.6
2.7.28 FETCHSIZE
The FETCHSIZE part contains one 4-byte integer value (little-endian) defining the number of rows the
application wants to fetch.
2.7.29 PARAMETERMETADATA
This part contains metadata (type information) of parameters, that is, input parameters of prepared
statements, and additional output parameters of stored procedure call statements.
A PARAMETERMETADATA part starts with an array of entries having the following structure:
Table 44:
Field Data Type Description
NAMEOFFSET UI4 Offset of parameter name in part, set to 0xFFFFFFFF to signal no name
The PARAMETEROPTIONS field is a bit set, which has the following defined values:
Table 45:
Bit Identifier Description
The MODE field is a bit set that defines the direction of a parameter:
Table 46:
Bit Identifier Description
The array of parameter descriptions may be followed by the names of the parameters. Here, each name is
written in the following format:
Table 47:
Field Data Type Description
A RESULTSETMETADATA part starts with an array of entries having the following structure:
Table 48:
Field Data Type Description
The COLUMNOPTIONS field is a bit set which has the following defined values:
Table 49:
Bit Identifier Description
The array of column descriptions may be followed by the individual schema names, table names, column
names, and column display names. Here, each name is written in the following format:
2.7.31 FINDLOBREQUEST
The FINDLOBREQUEST part is sent from the client to search for a substring of a BLOB, CLOB, NCLOB, or
TEXT value.
Table 51:
Field Data Type Description
2.7.32 FINDLOBREPLY
The FINDLOBREPLY part is sent from the database server to the client in response to a FINDLOBREQUEST
part.
It contains one 8-byte integer value (little-endian) defining the position within the locator of the search pattern.
The value is -1 to indicate that the pattern has not been found.
2.7.33 ITABSHM
This part describes how the memory used for ITAB transfer is sent to the SAP HANA database.
Table 52:
Field Data Type Description
Table 53:
Value Identifier Description
2.7.34 CLIENTINFO
The client info part contains key/value pairs, sent by the client for additional information.
The fields are formatted as variable length strings (like an NSTRING value in result set part). The argument
count is the number of strings in the part. Because these are key/value pairs, the argument count is always an
even number.
2.7.35 STREAMDATA
The STREAMDATA part contains stream data read or written by a C++ database procedure.
Its structure depends on the field information described by the corresponding ABAPITAB parameter.
2.7.36 BATCHPREPARE
2.7.37 BATCHEXECUTE
Table 54:
Value Identifier Data Type Description
STARTED
STARTED
The part is sent from the server to signal changes of the current transaction status (committed, rolled back,
start of a write transaction) and changes of the general session state, that is, whether the transaction isolation
level has been changed, or whether DDL statements are automatically committed or not. Also, the server can
signal it has detected a state that makes it impossible to continue processing the session.
2.7.39 DBCONNECTINFO
Table 55:
Value Identifier Data Type Description
In the request message, only the database name is sent. The replied message includes the ISCONNECTED
value, and may include HOST, and PORT values. The DATABASENAME value is not sent back.
Input fields generally consist of type code information, followed possibly by field data, if the value is not the
NULL value, with the following format:
The value is left blank if the type code indicates a NULL value (the MSB of the type code field is set). The
following sections only describe the VALUE format.
Output fields contain no special type code field. The type information is supplied in the respective
PARAMETERDATA (for output parameters) or RESULTSETMETADATA parts. All output data is densely
packed, that is, there are no gaps between individual values. Thus, some values may not be aligned in memory
as required for the native type.
2.8.1 TINYINT
Input TINYINT
Output TINYINT
Table 56:
Field Data Type Description
The field has a length of 2-bytes if the value is not NULL, and 1-byte if the value is NULL.
Input SMALLINT
Output SMALLINT
Table 57:
Field Data Type Description
The field has a length of 3-bytes if the value is not NULL, and 1-byte if the value is NULL.
2.8.3 INT
Input INT
Output INT
Table 58:
Field Data Type Description
The field has a length of 5-bytes if the value is not NULL, and 1-byte if the value is NULL.
2.8.4 BIGINT
Input BIGINT
Output BIGINT
Table 59:
Field Data Type Description
The field has a length of 9-bytes if the value is not NULL, and 1-byte if the value is NULL.
Input DECIMAL
Table 60:
Field Length Description
EXPONENT 14-bit Exponent, biased with 6176, leading to a range -6143 to +6144
The number represented is (10^EXPONENT)*MANTISSA. It is expected that MANTISSA is not a multiple of 10.
Output DECIMAL
A DECIMAL value is formatted similarly as the input format, with the NULL value indicated by having bits 4, 5,
and, 6 set to 1 in the last byte.
2.8.6 REAL
Input REAL
A REAL value is sent as float value (IEEE single precision floating point), in little-endian format.
Output REAL
A REAL value is sent as float value (IEEE single precision floating point), in little-endian format. The NULL value
is indicated by all bit sets in the value sent from the server (equal to 0xFFFFFFFF as unsigned int).
Input DOUBLE
A REAL value is sent as double value (IEEE double precision floating point), in little-endian format.
Output DOUBLE
A DOUBLE value is sent as double value (IEEE double precision floating point), in little-endian format. The
NULL value is indicated by all bit sets in the value sent from the server (equal to 0xFFFFFFFFFFFFFFFFul as
unsigned long).
2.8.8 STRING/NSTRING
Input STRING/NSTRING
The length in bytes of VALUE, if the VALUE length is less than or equal to 245
246, followed by a 2-byte integer (little-endian), which contains the actual length of VALUE
247, followed by a 4-byte integer (little-endian), which contains the actual length of VALUE
Output STRING/NSTRING
The formatting is similar to the input value, with a LENGTHINDICATOR value of 255 indicating a NULL value.
Input BINARY
A BINARY input value is formatted similarly as the STRING/NSTRING value, with respect to a
LENGTHINDICATOR and a VALUE part. The VALUE contains the binary data.
Output BINARY
The formatting is similar to the input value, with a LENGTHINDICATOR value of 255 indicating a NULL value.
2.8.10 BLOB/CLOB/NCLOB
Input BLOB/CLOB/NCLOB
A BLOB/CLOB/NCLOB field is indicated using an input LOB descriptor, followed by the LOB data after the end
of the record.
Table 61:
Field Data Type Description
The DATA field does not immediately follow the descriptor. First, all parameters of a row are transferred, and
then the BLOB/CLOB/NCLOB data follows.
Table 62:
Bit Identifier Description
Output BLOB/CLOB/NCLOB
A BLOB/CLOB/NCLOB field is formatted using an output LOB descriptor, followed by the LOB data.
Table 63:
Field Data Type Description
The TYPE field further refines the type code received in the result set metadata.
Table 64:
Value Data Type
1 BLOB
2 CLOB
3 NCLOB
Table 65:
Bit Identifier Description
2.8.11 DATE
YEAR I2 Year
MONTH I1 Month
DAY I2 Day
A NULL value is indicated by the MSB (0x8000) set in the YEAR field.
2.8.12 TIME
Table 67:
Field Data Type Description
HOUR I1 Hour
MINUTE I1 Minute
A NULL value is indicated by setting the MSB (0x80) in the HOUR field.
2.8.13 TIMESTAMP
Input TIMESTAMP
7 This format is retained for purpose of compatibility, DAYDATE is used where possible and the endorsed format.
8 This format is retained for compatibility purposes. SECONDTIME is used where possible and is the endorsed format.
9 This format is retained for compatibility purposes. The LONGDATE or SECONDDATE formats are used where possible and
are the endorsed formats.
A TIMESTAMP is formatted as a DATE value followed by a TIME value. A NULL value is indicated by setting the
NULL value in both components. For more information about the DATE and TIME formats, see Related
Information.
Related Information
2.8.14 ABAPITAB
2.8.15 ABAPSTRUCT
Input ABAPSTRUCT
An ABAPSTRUCT is formatted similarly as a BINARY value. The layout of the structure depends on meta-
information known only to the processing liveCache C++ Procedure and the ABAP client.
Output ABAPSTRUCT
2.8.16 LONGDATE
2.8.17 SECONDDATE
2.8.18 DAYDATE
A DAYDATE is computed by taking the Julian Day Number of the specified date and subtracting 1721423.
2.8.19 SECONDTIME
Input ST_POINT/ST_POINTZ/ST_GEOMETRY
The following section depicts common scenarios and the parameters that apply.
As laid out in the sequence diagram below, the authentication and connection process consist of possibly a
number of AUTHENTICATE messages, finally concluded with the exchanging of a CONNECT message.
For several fields in the authentication request a LENGTHINDICATOR is used. It can be up to 5-bytes:
The length in bytes of the following value, if the length is less 250
250, followed by a 2-byte integer (little-endian) which contains the actual length of the value
The following sections explain, in detail, the processing of the various authentication methods.
Following the SCRAMSHA256 authentication mechanism two server roundtrips are necessary, an initial
request and a final request.
Table 68:
Field Data Type Description
Table 69:
Field Data Type Description
Table 70:
Field Data Type Description
Table 71:
Field Data Type Description
Table 72:
Field Data Type Description
Table 73:
Field Data Type Description
Table 74:
Field Data Type Description
Table 75:
Field Data Type Description
Table 76:
Field Data Type Description
Table 78:
Field Data Type Description
Table 79:
Field Data Type Description
Table 80:
Field Data Type Description
Session cookies can only be used in case of a reconnection. The cookie is obtained from a previous
connection. It makes two server roundtrips.
Table 81:
Field Data Type Description
Table 82:
Field Data Type Description
Table 83:
Field Data Type Description
Table 84:
Field Data Type Description
Direct statement execution is the simplest way to execute statements in a database session.
The server replies to the EXECUTEDIRECT message sent by the client either with:
A returned error, indicating failure (such as, a syntax error) of the SQL statement
A message containing the result of query execution, this may be, depending on the returned
FUNCTIONCODE:
If the result set data has not been completely transmitted, the process explained in Fetching Result Set Data
must be followed to retrieve the remaining data.
Definition
Statement routing is the method of evaluating the correct server node of a distributed system before
statement execution, thus reducing the overhead in server processing and reducing communication between
server nodes.
Preconditions
The server decides which statements are eligible for statement routing. When preparing a statement, a
TABLELOCATION part or a PARTITIONINFORMATION part is returned by the server to describe the preferred
nodes in detail.
FAE For All Entries. A specific ABAP Language construct, where a client-side table is joined with a server-
side table.
FDA Fast Data Access. A method to submit data for INSERT in the format used by the SAP ABAP
Application Server (ABAP Table) to the server or retrieve SELECT results in the same format, to avoid
field-wise copying and data conversion.
MSB Most Significant Bit. The highest bit in an integer value, for example, Bit 7 in a byte.
There are several types of licenses available for SAP HANA. Depending on the license type of your SAP HANA
installation, some of the features and tools that are described in the SAP HANA platform documentation may
only be available via the SAP HANA options, which may be released independently of an SAP HANA Platform
Support Package Stack (SPS). Although various features included in SAP HANA options are cited in the SAP
HANA platform documentation, customers who only purchased the license for the base edition of the SAP
HANA platform do not have the right to use features included in SAP HANA options, because these features
are not included in the license of the base edition of the SAP HANA platform. For customers to whom these
license restrictions apply, the use of features included in SAP HANA options in a production system requires
purchasing the corresponding software license(s) from SAP. The documentation for the SAP HANA optional
components is available in SAP Help Portal at http://help.sap.com/hana_options. For more information, see
also SAP Note 2091815 - SAP HANA Options If you have additional questions about what your particular
license provides, or wish to discuss licensing features available in SAP HANA options, please contact your SAP
account team representative.
Coding Samples
Any software coding and/or code lines / strings ("Code") included in this documentation are only examples and are not intended to be used in a productive system
environment. The Code is only intended to better explain and visualize the syntax and phrasing rules of certain coding. SAP does not warrant the correctness and
completeness of the Code given herein, and SAP shall not be liable for errors or damages caused by the usage of the Code, unless damages were caused by SAP
intentionally or by SAP's gross negligence.
Accessibility
The information contained in the SAP documentation represents SAP's current view of accessibility criteria as of the date of publication; it is in no way intended to be
a binding guideline on how to ensure accessibility of software products. SAP in particular disclaims any liability in relation to this document. This disclaimer, however,
does not apply in cases of wilful misconduct or gross negligence of SAP. Furthermore, this document does not result in any direct or indirect contractual obligations of
SAP.
Gender-Neutral Language
As far as possible, SAP documentation is gender neutral. Depending on the context, the reader is addressed directly with "you", or a gender-neutral noun (such as
"sales person" or "working days") is used. If when referring to members of both sexes, however, the third-person singular cannot be avoided or a gender-neutral noun
does not exist, SAP reserves the right to use the masculine form of the noun and pronoun. This is to ensure that the documentation remains comprehensible.
Internet Hyperlinks
The SAP documentation may contain hyperlinks to the Internet. These hyperlinks are intended to serve as a hint about where to find related information. SAP does
not warrant the availability and correctness of this related information or the ability of this information to serve a particular purpose. SAP shall not be liable for any
damages caused by the use of related information unless damages have been caused by SAP's gross negligence or willful misconduct. All links are categorized for
transparency (see: http://help.sap.com/disclaimer).