src.com.ibm.as400.access.DBSQLRequestDS Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400-jdk9 Show documentation
Show all versions of jt400-jdk9 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: DBSQLRequestDS.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2003 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.sql.SQLException; //@E9a
/**
The DBSQLRequestDS class represents a request datastream
to the SQL server.
**/
class DBSQLRequestDS
extends DBBaseRequestDS
{
private static final String copyright = "Copyright (C) 1997-2003 International Business Machines Corporation and others.";
// Function ids.
public static final int FUNCTIONID_CLEAR_PACKAGE = 0x1810;
public static final int FUNCTIONID_CLOSE = 0x180A;
public static final int FUNCTIONID_CONNECT = 0x1809;
public static final int FUNCTIONID_COMMIT = 0x1807;
public static final int FUNCTIONID_CREATE_PACKAGE = 0x180F;
public static final int FUNCTIONID_DELETE_PACKAGE = 0x1811;
public static final int FUNCTIONID_DESCRIBE = 0x1801;
public static final int FUNCTIONID_DESCRIBE_PARM_MARKER = 0x1802;
public static final int FUNCTIONID_END_STREAM_FETCH = 0x1813;
public static final int FUNCTIONID_EXECUTE = 0x1805;
public static final int FUNCTIONID_EXECUTE_IMMEDIATE = 0x1806;
public static final int FUNCTIONID_EXECUTE_OPEN_DESCRIBE = 0x1812;
public static final int FUNCTIONID_FETCH = 0x180B;
public static final int FUNCTIONID_OPEN_DESCRIBE = 0x1804;
public static final int FUNCTIONID_OPEN_DESCRIBE_FETCH = 0x180E;
public static final int FUNCTIONID_PREPARE = 0x1800;
public static final int FUNCTIONID_PREPARE_DESCRIBE = 0x1803;
public static final int FUNCTIONID_PREPARE_EXECUTE = 0x180D;
public static final int FUNCTIONID_RETRIEVE_LOB_DATA = 0x1816;
public static final int FUNCTIONID_RETURN_PACKAGE = 0x1815;
public static final int FUNCTIONID_ROLLBACK = 0x1808;
public static final int FUNCTIONID_STREAM_FETCH = 0x180C;
public static final int FUNCTIONID_WRITE_LOB_DATA = 0x1817;
public static final int FUNCTIONID_CANCEL = 0x1818; // @E2A
public static final int FUNCTIONID_TEST_CONNECTION = 0x0000; //@pda jdbc40 used for Connection.isValid
public static final int FUNCTIONID_FREE_LOB = 0x1819; //@pda jdbc40 lob.free() //@pdc
// Fetch scroll options.
public static final int FETCH_NEXT = 0x0000;
public static final int FETCH_PREVIOUS = 0x0001;
public static final int FETCH_FIRST = 0x0002;
public static final int FETCH_LAST = 0x0003;
public static final int FETCH_BEFORE_FIRST = 0x0004;
public static final int FETCH_AFTER_LAST = 0x0005;
public static final int FETCH_CURRENT = 0x0006;
public static final int FETCH_RELATIVE = 0x0007;
public static final int FETCH_DIRECT = 0x0008; //@abs2
//@F6A Constants for cursor sensitivity property (for >= v5r2 systems)
public static final int CURSOR_NOT_SCROLLABLE_ASENSITIVE = 0;
public static final int CURSOR_SCROLLABLE_ASENSITIVE = 1;
public static final int CURSOR_SCROLLABLE_INSENSITIVE = 2;
public static final int CURSOR_SCROLLABLE_SENSITIVE = 3;
public static final int CURSOR_NOT_SCROLLABLE_SENSITIVE = 4;
public static final int CURSOR_NOT_SCROLLABLE_INSENSITIVE = 5;
/**
Constructs a datastream for the SQL Server request functions.
@param requestId the 4 digit code that represents the function being called.
@param rpbId the request parameter block id.
@param operationResultsBitmap the bitmap which describes how the results are to be returned.
@param parameterMarkerDescriptorHandle the Parameter marker descriptor handle identifier.
**/
public DBSQLRequestDS(int requestId,
int rpbId,
int operationResultsBitmap,
int parameterMarkerDescriptorHandle)
{
// Create the datastream header and template
super(requestId, rpbId, operationResultsBitmap,
parameterMarkerDescriptorHandle);
setServerID(SERVER_SQL);
}
/**
Sets the Blocking Factor parameter in the data stream.
@param value the blocking factor to be used on the fetch.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setBlockingFactor(int value)
throws DBDataStreamException
{
addParameter (0x380C, value);
}
//@F2A
/**
Sets the Column Index parameter in the data stream.
@param value the column index to be used on a Retrieve LOB Data.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setColumnIndex(int value)
throws DBDataStreamException
{
addParameter (0x3828, value);
}
/**
Sets the Compression Indicator parameter in the data stream.
@param value the value that indicates whether the LOB data
should be compressed.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setCompressionIndicator (int value)
throws DBDataStreamException
{
addParameter (0x381B, (byte)value);
}
void setReturnCurrentLengthIndicator(int value) // @E1A
throws DBDataStreamException // @E1A
{ // @E1A
addParameter(0x3821, (byte)value); // @E1A
} // @E1A
/**
Sets the Cursor Name parameter in the data stream.
@param value the name for the open cursor.
@param converter the converter.
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setCursorName (String value, ConvTable converter) //@P0C
throws DBDataStreamException, SQLException // @E9c
{
addParameter (0x380B, converter, value);
}
/**
Sets the Describe Option parameter in the data stream.
@param value the describe option to be used.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setDescribeOption(int value)
throws DBDataStreamException
{
addParameter (0x380A, (byte)value);
}
//@F5A
/**
Sets the Extended Column Descriptor Option parameter in the data stream.
@param value the extended column descriptor option to be used.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setExtendedColumnDescriptorOption(int value)
throws DBDataStreamException
{
addParameter (0x3829, (byte)value);
}
/**
Sets the Fetch Scroll Option parameter in the data stream.
@param value the scroll option to used with the cursor.
@param rows the number of rows, when value is FETCH_RELATIVE.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setFetchScrollOption(int value, int rows)
throws DBDataStreamException
{
// The system gives an error when we pass rows
// and value != FETCH_RELATIVE.
if (value == FETCH_RELATIVE || value == FETCH_DIRECT) //@abs2
addParameter (0x380E, (short)value, rows);
else
addParameter (0x380E, (short)value);
}
/**
Sets the Hold Indicator parameter in the data stream.
@param value the commit operation that is to be performed.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setHoldIndicator(int value)
throws DBDataStreamException
{
addParameter (0x380F, (byte)value);
}
void setJobIdentifier(String value, ConvTable converter) // @E2A @P0C
throws DBDataStreamException, SQLException // @E9c @E2A
{ // @E2A
addParameter(0x3826, converter, value); // @E2A
} // @E2A
/**
Sets the Library Name parameter in the data stream.
@param value the name of the library.
@param converter the converter.
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setLibraryName (String value, ConvTable converter) //@P0C
throws DBDataStreamException, SQLException // @E9c
{
addParameter (0x3801, converter, value);
}
/**
Sets the LOB Allocate Locator Indicator parameter in the data stream.
@param value the value that indicates whether a LOB locator
should be allocated for this request.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setLOBAllocateLocatorIndicator (int value)
throws DBDataStreamException
{
addParameter (0x381C, (byte)value);
}
/**
Sets the LOB Data parameter in the data stream.
@param value the LOB data.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setLOBData (byte[] value)
throws DBDataStreamException
{
addParameter (0x381D, value, true); // @C1C
}
void setLOBData(byte[] value, int offset, int length) throws DBDataStreamException
{
addParameter(0x381D, value, offset, length, true);
}
/**
Sets the LOB Locator Handle parameter in the data stream.
@param value the LOB locator handle.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setLOBLocatorHandle (int value)
throws DBDataStreamException
{
addParameter (0x3818, value);
}
/**
Sets the Open Attributes parameter in the data stream.
@param value the open attributes of the referenced file.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setOpenAttributes(int value)
throws DBDataStreamException
{
addParameter (0x3809, (byte)value);
}
/**
Sets the SQL Package Name parameter in the data stream.
@param value the name of the SQL package to use.
@param converter the converter.
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setPackageName (String value, ConvTable converter) //@P0C
throws DBDataStreamException, SQLException // @E9c
{
if(value == null)
{
addParameter(0x3804); //send an empty code point
}
else
addParameter (0x3804, converter, value);
}
// $F1 This parameter no longer needs to be passed on a data stream. Package clearing
// $F1 and the decision for the threshold where package clearing is needed is now handled
// $F1 automatically by the database. Passing this code point results in a no-op.
//@F1D /**
//@F1D Sets the Package Threshold Value parameter in the data stream.
//@F1D @param value the value used to determine if the package
//@F1D should be cleared.
//@F1D @exception DBDataStreamException If there is not enough space left in the data byte array.
//@F1D **/
//@F1D void setPackageThresholdValue(int value)
//@F1D throws DBDataStreamException
//@F1D {
//@F1D addParameter (0x3813, (short)value);
//@F1D }
/**
Sets the Parameter Marker Block Indicator parameter in the data stream.
@param value the value that indicates whether the parameter
marker data is intended for a block operation or a non-block operation.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setParameterMarkerBlockIndicator(int value)
throws DBDataStreamException
{
addParameter (0x3814, (short)value);
}
/**
Sets the Parameter Marker Data parameter in the data stream.
@param value the parameter marker data object.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setParameterMarkerData(DBData value)
throws DBDataStreamException
{
if (value instanceof DBOriginalData)
addParameter (0x3811, value);
else if (value instanceof DBExtendedData)
addParameter (0x381F, value);
else if (value instanceof DBVariableData) //@array
addParameter (0x382F, value); //@array
else
throw new DBDataStreamException ();
}
/** This is a version of setParameterMarkerData that returns the offset where the
* length in the request should be updated using request.updateLength(offset, newLength);
* @param value
* @return offset after adding marker
* @throws DBDataStreamException
*/
// @K3A
public int setParameterMarkerDataReserve(DBData value) throws DBDataStreamException{
int offset;
if (value instanceof DBOriginalData)
offset = addParameterReserve (0x3811, value);
else if (value instanceof DBExtendedData)
offset = addParameterReserve (0x381F, value);
else if (value instanceof DBVariableData)
offset = addParameterReserve (0x382F, value);
else
throw new DBDataStreamException ();
return offset;
}
/**
Sets the Prepare Option parameter in the data stream.
@param value the prepare option to use.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setPrepareOption(int value)
throws DBDataStreamException
{
addParameter (0x3808, (byte)value);
}
/**
Sets the Prepare Statement Name parameter in the data stream.
@param value the name of the parameter statement.
@param converter the converter.
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setPrepareStatementName (String value, ConvTable converter) //@P0C
throws DBDataStreamException, SQLException // @E9c
{
addParameter (0x3806, converter, value);
}
/**
Sets the Requested Size parameter in the data stream.
@param value the request size, in bytes.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setRequestedSize (int value)
throws DBDataStreamException
{
addParameter (0x3819, value);
}
//@F3A
/**
Sets the ResultSet Holdability Option parameter in the data stream.
@param value the value that contains the option to indicate how the cursor should
be opened.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setResultSetHoldabilityOption(byte value)
throws DBDataStreamException
{
addParameter (0x3830, value);
}
/**
Sets the Return Size parameter in the data stream.
@param value the value that indicates the number
of megabytes of data to return from the package.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setReturnSize(int value)
throws DBDataStreamException
{
addParameter (0x3815, value);
}
/**
Sets the Reuse Indicator parameter in the data stream.
@param value the value that indicates if the client
intends to open the cursor again for the same statement or not.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setReuseIndicator(int value)
throws DBDataStreamException
{
addParameter (0x3810, (byte)value);
}
/**
Sets the Scrollable Cursor Flag parameter in the data stream.
@param value the value to indicate whether or not
cursor scrolling is supported.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setScrollableCursorFlag(int value)
throws DBDataStreamException
{
addParameter (0x380D, (short)value);
}
/**
Sets the Start Offset parameter in the data stream.
@param value the start offset, in bytes.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setStartOffset (int value)
throws DBDataStreamException
{
addParameter (0x381A, value);
}
/**
Sets the Statement Text parameter in the data stream.
@param value the text for the SQL statement.
@param converter the converter.
@param extended true if using extended statement text, false otherwise
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setStatementText (String value, ConvTable converter, boolean extended) //@P0C //@540C
throws DBDataStreamException, SQLException // @E9c
{
if(!extended)
addParameter (0x3807, converter, value);
else
setExtendedStatementText(value, converter);
}
//@540
/**
Sets the Extended Statement Text parameter in the data stream.
@param value the text for the SQL statement.
@param converter the converter.
@exception DBDataStreamException If there is not enough space left in the data byte array.
@exception SQLException If the SQL statement is too long.
**/
void setExtendedStatementText (String value, ConvTable converter)
throws DBDataStreamException, SQLException
{
addParameter (0x3831, true, converter, value);
}
/**
Sets the Statement Type parameter in the data stream.
@param value the statement type.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setStatementType (int value)
throws DBDataStreamException
{
addParameter (0x3812, (short)value);
}
/**
Sets the Translate Indicator parameter in the data stream.
@param value the value that indicates if the data in the
operational result set generated by this function should be
translated to the client's CCSID before the data is returned.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setTranslateIndicator(int value)
throws DBDataStreamException
{
addParameter (0x3805, (byte)value);
}
//@K1A
/**
Sets the Truncation Indicator parameter in the data stream to specify whether or not the LOB data should be
truncated after the last byte is written in the write LOB data request
@param value the value that indicates if the data should be truncated
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setLobTruncation (boolean truncate)
throws DBDataStreamException
{
int value = 0xF0;
if(truncate == false)
{
value = 0xF1;
}
addParameter (0x3822, (byte)value);
}
//@K54
/**
Sets the Variable-length Field Compression parameter in the data stream to specify whether or not Variable-length fields
should be compressed. By default, variable-length fields are not compressed.
@param value the value that indicates if variable-length fields should be compressed.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setVariableFieldCompression(boolean compressed)
throws DBDataStreamException
{
if(compressed)
addParameter(0x3833, (byte)0xE8);
else
addParameter(0x3833, (byte)0xD5);
}
//@K54
/**
Sets the buffer size parameter in the data stream.
@param value the buffer size to be used on the fetch.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
void setBufferSize(int value)
throws DBDataStreamException
{
addParameter (0x3834, value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy