Adaptive Server can send large chunks of data in a single remote procedure call. This is done by treating certain parameters as text pointers, then dereferencing these text pointers to obtain the text values associated with them. The text data is then packaged into 16K chunks for Adaptive Server and 32K chunks for all other servers, and handed to Client-Library as parameters to the RPC.
A text pointer is identified as a parameter of type binary(16) or varbinary(16). The text value referenced by each text pointer parameter is obtained when the RPC is executed, and expanded into 16K chunks for Adaptive Server and 32K chunks for all other servers, each of which is passed to Client-Library as a parameter of type CS_LONGCHAR_TYPE.
This behavior is triggered by this set command:
set textptr_parameters ON
When an RPC is requested (cis_rpc_handling must be on), text pointers are dereferenced in the Component Integration Services layer, and the text value obtained is used to construct one or more parameters for Client-Library.
For this to work, the text pointers must be preceded by a path name argument, which is used to identify the table from which the text pointers have been derived. For example:
declare @pathname varchar(90) declare @textptr1 binary(16) declare @textptr2 binary(16) select @pathname = "mydatabase.dbo.t1", @textptr1 = textptr(c1), @textptr2 = textptr(c2) from mydatabase.dbo.t1 where ... (whatever) set textptr_parameters ON exec NETGW...myrpc @pathname, @textptr1, @textptr2 set textptr_parameters OFF
When the RPC named ‘myrpc’ gets sent to server NETGW, the @pathname parameter is not actually sent, but is used to help locate the text values referenced by the textptr’s @textptr1 and @textptr2.
The varchar parameter @pathname must immediately precede the binary(16) parameter, otherwise @textptr1 is considered an ordinary parameter and is transmitted to the server NETGW as a normal binary(16) value.
The text will be broken into 16K or 32K chunks, each of which is a separate parameter of type CS_LONGCHAR_TYPE.
The current value of @@textsize is ignored.
This scheme is also designed to work with proxy tables mapped to remote procedures. For example:
create existing table myrpctable ( id int, -- result column crdate datetime, -- result column name varchar(30), -- result column _pathname varchar(90), -- parameter column _textptr1 binary(16), -- parameter column _textptr2 binary(16), -- parameter column ) external procedure at ’NETGW...myrpc’ go declare @textptr1 binary(16) declare @textptr2 binary(16) select @textptr1 = textptr(c1), @textptr2 = textptr(c2) from mydatabase.dbo.t1 where <whatever> set textptr_parameters ON select id, crdate, name from myrpctable where_pathname = "mydatabase.dbo.t1" and _textptr1 = @textptr1 and _textptr2 = @textptr2
When the query against the proxy table myrpctable is processed, Component Integration Services sends an RPC named ‘myrpc’ to the server ‘NETGW’. The parameters will be derived from the search arguments contained in the where clause of the query. Since the textptr_parameter option has been set ON, the textptrs are expanded to CS_LONGCHAR_TYPE, as in the case of the RPC example shown previously.