src.com.ibm.as400.access.JDConnectionProxy Maven / Gradle / Ivy
Show all versions of jt400 Show documentation
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: JDConnectionProxy.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-2010 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.lang.reflect.InvocationTargetException;
import java.sql.Array;
import java.sql.Blob;
import java.sql.CallableStatement;
/* ifdef JDBC40
import java.sql.ClientInfoStatus;
endif */
import java.sql.Clob;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
/* ifdef JDBC40
import java.sql.NClob;
endif */
import java.sql.PreparedStatement;
/* ifdef JDBC40
import java.sql.SQLClientInfoException;
import java.sql.SQLXML;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.concurrent.Executor;
endif */
import java.sql.Savepoint;
import java.sql.SQLException;
import java.sql.SQLWarning;
import java.sql.Statement;
import java.sql.Struct;
import java.util.Map;
import java.util.Properties;
class JDConnectionProxy
extends AbstractProxyImpl
implements Connection
{
static final String copyright = "Copyright (C) 1997-2006 International Business Machines Corporation and others.";
// Private data.
private JDDatabaseMetaDataProxy metaData_;
AS400 as400PublicClassObj_; // Prevents garbage collection.
// Copied from JDError:
private static final String EXC_FUNCTION_NOT_SUPPORTED = "IM001";
private Object callFactoryMethod (String methodName,
Class[] argClasses,
Object[] argValues,
ProxyFactoryImpl proxyObject)
throws SQLException
{
try {
if (argClasses == null)
return connection_.callFactoryMethod (
pxId_,
methodName,
proxyObject);
else
return connection_.callFactoryMethod (
pxId_,
methodName,
argClasses,
argValues,
proxyObject);
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
private void callMethod (String methodName)
throws SQLException
{
try {
connection_.callMethod (pxId_, methodName);
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
private void callMethod (String methodName,
Class[] argClasses,
Object[] argValues)
throws SQLException
{
try {
connection_.callMethod (pxId_, methodName, argClasses, argValues);
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
private boolean callMethodRtnBool (String methodName)
throws SQLException
{
try {
return connection_.callMethodReturnsBoolean (pxId_, methodName);
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
private Object callMethodRtnObj (String methodName)
throws SQLException
{
try {
return connection_.callMethodReturnsObject (pxId_, methodName);
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
//@PDA 550
private Object callMethodRtnObj(String methodName, Class[] argClasses, Object[] argValues) throws SQLException
{
try
{
return connection_.callMethod(pxId_, methodName, argClasses, argValues).getReturnValue();
} catch (InvocationTargetException e)
{
throw rethrow1(e);
}
}
public void clearWarnings ()
throws SQLException
{
callMethod ("clearWarnings");
}
public void close ()
throws SQLException
{
callMethod ("close");
}
public void commit ()
throws SQLException
{
callMethod ("commit");
}
// This implements the ProxyImpl interface.
public void construct (ProxyClientConnection connection)
{
connection_ = connection;
// Note: We need to check for a secondary URL (in setProperties)
// before we know what kind of remote object to create,
// therefore we simply capture the 'connection' value here.
}
public Statement createStatement ()
throws SQLException
{
JDStatementProxy newStatement = new JDStatementProxy (this);
return (JDStatementProxy) callFactoryMethod (
"createStatement", null, null,
newStatement);
}
// JDBC 2.0
public Statement createStatement (int resultSetType,
int resultSetConcurrency)
throws SQLException
{
JDStatementProxy newStatement = new JDStatementProxy (this);
return (JDStatementProxy) callFactoryMethod (
"createStatement",
new Class[] { Integer.TYPE, Integer.TYPE },
new Object[] { new Integer(resultSetType),
new Integer(resultSetConcurrency) },
newStatement);
}
// JDBC 3.0
public Statement createStatement (int resultSetType,
int resultSetConcurrency,
int resultSetHoldability)
throws SQLException
{
JDStatementProxy newStatement = new JDStatementProxy (this);
return(JDStatementProxy) callFactoryMethod (
"createStatement",
new Class[] { Integer.TYPE, Integer.TYPE,
Integer.TYPE},
new Object[] { new Integer(resultSetType),
new Integer(resultSetConcurrency),
new Integer(resultSetHoldability)},
newStatement);
}
public boolean getAutoCommit ()
throws SQLException
{
return callMethodRtnBool ("getAutoCommit");
}
public String getCatalog ()
throws SQLException
{
return (String) callMethodRtnObj ("getCatalog");
}
//@cc1
/**
* This method returns the concurrent access resolution setting.
* This method has no effect on IBM i V6R1 or earlier.
* The possible values for this property are {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME} and
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS},
* with the property defaulting to {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET}.
* Setting this property to default exhibits the default behavior on the servers
* i.e., the semantic applied for read
* transactions to avoid locks will be determined by the server.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED} specifies that driver will flow USE CURRENTLY COMMITTED
* to server. Whether CURRENTLY COMMITTED will actually be in effect is
* ultimately determined by server.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME} specifies that driver will flow WAIT FOR OUTCOME
* to server. This will disable the CURRENTLY COMMITTED behavior at the server,
* if enabled, and the server will wait for the commit or rollback of data in the process of
* being updated.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS} specifies that driver will flow SKIP LOCKS
* to server. This directs the database manager to skip records in the case of record lock conflicts.
*
* @return The concurrent access resolution setting. Possible return valuse:
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME}, or
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS}
* @throws SQLException
*/
public int getConcurrentAccessResolution () throws SQLException
{
return ((Integer)callMethodRtnObj ("getConcurrentAccessResolution")).intValue();
}
// JDBC 3.0
public int getHoldability ()
throws SQLException
{
return ((Integer)callMethodRtnObj ("getHoldability")).intValue();
}
public DatabaseMetaData getMetaData ()
throws SQLException
{
if (metaData_ == null)
{
JDDatabaseMetaDataProxy newMetaData = new JDDatabaseMetaDataProxy (this);
metaData_ = (JDDatabaseMetaDataProxy) callFactoryMethod (
"getMetaData", null, null,
newMetaData);
}
return metaData_;
}
public int getTransactionIsolation ()
throws SQLException
{
try {
return connection_.callMethodReturnsInt (pxId_, "getTransactionIsolation");
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
// JDBC 2.0
public Map getTypeMap ()
throws SQLException
{
return (Map) callMethodRtnObj ("getTypeMap");
}
public SQLWarning getWarnings ()
throws SQLException
{
return (SQLWarning) callMethodRtnObj ("getWarnings");
}
public boolean isClosed ()
throws SQLException
{
return callMethodRtnBool ("isClosed");
}
public boolean isReadOnly ()
throws SQLException
{
return callMethodRtnBool ("isReadOnly");
}
public String nativeSQL (String sql)
throws SQLException
{
try {
return (String) connection_.callMethod (pxId_, "nativeSQL",
new Class[] { String.class },
new Object[] { sql })
.getReturnValue ();
}
catch (InvocationTargetException e) {
throw rethrow1 (e);
}
}
public CallableStatement prepareCall (String sql)
throws SQLException
{
JDCallableStatementProxy newStatement = new JDCallableStatementProxy (this);
return (JDCallableStatementProxy) callFactoryMethod (
"prepareCall",
new Class[] { String.class },
new Object[] { sql },
newStatement);
}
// JDBC 2.0
public CallableStatement prepareCall (String sql,
int resultSetType,
int resultSetConcurrency)
throws SQLException
{
JDCallableStatementProxy newStatement = new JDCallableStatementProxy (this);
return (JDCallableStatementProxy) callFactoryMethod (
"prepareCall",
new Class[] { String.class, Integer.TYPE,
Integer.TYPE },
new Object[] { sql,
new Integer(resultSetType),
new Integer(resultSetConcurrency) },
newStatement);
}
// JDBC 3.0
public CallableStatement prepareCall (String sql,
int resultSetType,
int resultSetConcurrency,
int resultSetHoldability)
throws SQLException
{
JDCallableStatementProxy newStatement = new JDCallableStatementProxy (this);
return(JDCallableStatementProxy) callFactoryMethod (
"prepareCall",
new Class[] { String.class, Integer.TYPE,
Integer.TYPE, Integer.TYPE},
new Object[] { sql,
new Integer(resultSetType),
new Integer(resultSetConcurrency),
new Integer(resultSetHoldability)},
newStatement);
}
public PreparedStatement prepareStatement (String sql)
throws SQLException
{
JDPreparedStatementProxy newStatement = new JDPreparedStatementProxy (this);
return (JDPreparedStatementProxy) callFactoryMethod (
"prepareStatement",
new Class[] { String.class },
new Object[] { sql },
newStatement);
}
// JDBC 3.0
public PreparedStatement prepareStatement (String sql, int autoGeneratedKeys)
throws SQLException
{
JDPreparedStatementProxy newStatement = new JDPreparedStatementProxy (this);
return(JDPreparedStatementProxy) callFactoryMethod (
"prepareStatement",
new Class[] { String.class, Integer.TYPE},
new Object[] { sql,
new Integer(autoGeneratedKeys)},
newStatement);
}
// JDBC 3.0
public PreparedStatement prepareStatement (String sql, int[] columnIndexes)
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
// JDBC 3.0
public PreparedStatement prepareStatement (String sql, String[] columnNames)
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
// JDBC 2.0
public PreparedStatement prepareStatement (String sql,
int resultSetType,
int resultSetConcurrency)
throws SQLException
{
JDPreparedStatementProxy newStatement = new JDPreparedStatementProxy (this);
return (JDPreparedStatementProxy) callFactoryMethod (
"prepareStatement",
new Class[] { String.class, Integer.TYPE,
Integer.TYPE },
new Object[] { sql,
new Integer(resultSetType),
new Integer(resultSetConcurrency) },
newStatement);
}
// JDBC 3.0
public PreparedStatement prepareStatement (String sql,
int resultSetType,
int resultSetConcurrency,
int resultSetHoldability)
throws SQLException
{
JDPreparedStatementProxy newStatement = new JDPreparedStatementProxy (this);
return(JDPreparedStatementProxy) callFactoryMethod (
"prepareStatement",
new Class[] { String.class, Integer.TYPE,
Integer.TYPE, Integer.TYPE},
new Object[] { sql,
new Integer(resultSetType),
new Integer(resultSetConcurrency),
new Integer(resultSetHoldability)},
newStatement);
}
// JDBC 3.0
public void releaseSavepoint (Savepoint savepoint)
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
static InternalErrorException rethrow1 (InvocationTargetException e)
throws SQLException
{
Throwable e2 = e.getTargetException ();
if (e2 instanceof SQLException)
throw (SQLException) e2;
else
return ProxyClientConnection.rethrow (e);
}
public void rollback ()
throws SQLException
{
callMethod ("rollback");
}
// JDBC 3.0
public void rollback (Savepoint savepoint)
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
public void setAutoCommit (boolean autoCommit)
throws SQLException
{
callMethod ("setAutoCommit",
new Class[] { Boolean.TYPE },
new Object[] { new Boolean(autoCommit) });
}
public void setCatalog (String catalog)
throws SQLException
{
callMethod ("setCatalog",
new Class[] { String.class },
new Object[] { catalog });
}
//@cc1
/**
* This method sets concurrent access resolution. This method overrides the setting of ConcurrentAccessResolution on the datasource or connection
* URL properties. This changes the setting for this connection only. This method has no effect on
* IBM i V6R1 or earlier.
* The possible values for this property are {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME} and
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS},
* with the property defaulting to {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET}.
* Setting this property to default exhibits the default behavior on the servers
* i.e., the semantic applied for read
* transactions to avoid locks will be determined by the server.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED} specifies that driver will flow USE CURRENTLY COMMITTED
* to server. Whether CURRENTLY COMMITTED will actually be in effect is
* ultimately determined by server.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME} specifies that driver will flow WAIT FOR OUTCOME
* to server. This will disable the CURRENTLY COMMITTED behavior at the server,
* if enabled, and the server will wait for the commit or rollback of data in the process of
* being updated.
*
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS} specifies that driver will flow SKIP LOCKS
* to server. This directs the database manager to skip records in the case of record lock conflicts.
*
* @param concurrentAccessResolution The current access resolution setting. Possible valuse:
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_NOT_SET},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_USE_CURRENTLY_COMMITTED},
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_WAIT_FOR_OUTCOME}, or
* {@link com.ibm.as400.access.AS400JDBCDataSource#CONCURRENTACCESS_SKIP_LOCKS}
* @throws SQLException
*/
public void setConcurrentAccessResolution (int concurrentAccessResolution) throws SQLException
{
callMethod ("setConcurrentAccessResolution",
new Class[] { Integer.TYPE},
new Object[] { new Integer(concurrentAccessResolution)});
}
// JDBC 3.0
public void setHoldability (int holdability)
throws SQLException
{
callMethod ("setHoldability",
new Class[] { Integer.TYPE},
new Object[] { new Integer(holdability)});
}
// Copied from JDError:
private static final String EXC_CONNECTION_REJECTED = "08004";
private static final String EXC_CONNECTION_UNABLE = "08001";
// Note: This method is used by AS400JDBCDriver.
void setProperties (JDDataSourceURL dataSourceUrl, JDProperties properties,
AS400 as400)
throws SQLException
{
String remoteClassName;
Class[] argClasses;
Object[] argValues;
String secondaryUrl = dataSourceUrl.getSecondaryURL ();
if (secondaryUrl.length() == 0) {
remoteClassName = "AS400JDBCConnection";
argClasses = new Class[] { JDDataSourceURL.class,
JDProperties.class,
AS400Impl.class };
argValues = new Object[] { dataSourceUrl, properties, as400.getImpl() };
try {
as400.connectService (AS400.DATABASE);
}
catch (AS400SecurityException e) { //@A0C
// Avoid dragging in JDError:
if (JDTrace.isTraceOn ()) {
JDTrace.logException(this, "Security Exception caught", e);
}
SQLException sqlex = new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_CONNECTION_REJECTED),
EXC_CONNECTION_REJECTED, -99999);
sqlex.initCause(e);
throw sqlex;
}
catch (java.io.IOException e) { //@A0C
// Avoid dragging in JDError:
if (JDTrace.isTraceOn ()) {
JDTrace.logException(this, "IOException caught", e);
}
SQLException sqlex = new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_CONNECTION_UNABLE),
EXC_CONNECTION_UNABLE, -99999);
sqlex.initCause(e);
throw sqlex;
}
}
else
{ // A secondary URL was specified, so get a generic connection.
remoteClassName = "JDGenericConnection";
argClasses = new Class[] { String.class, Properties.class };
argValues = new Object[] { secondaryUrl, properties.getOriginalInfo() };
}
try {
pxId_ = connection_.callConstructor (remoteClassName, false);
}
catch (InvocationTargetException e) {
throw ProxyClientConnection.rethrow (e);
}
callMethod ("setProperties", argClasses, argValues);
}
public void setReadOnly (boolean readOnly)
throws SQLException
{
callMethod ("setReadOnly",
new Class[] { Boolean.TYPE },
new Object[] { new Boolean(readOnly) });
}
// JDBC 3.0
public Savepoint setSavepoint ()
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
// JDBC 3.0
public Savepoint setSavepoint (String name)
throws SQLException
{
// Avoid dragging in JDError
throw new SQLException (
AS400JDBCDriver.getResource("JD" + EXC_FUNCTION_NOT_SUPPORTED),
EXC_FUNCTION_NOT_SUPPORTED, -99999);
}
void setSystem (AS400 as400)
{
as400PublicClassObj_ = as400;
}
public void setTransactionIsolation (int level)
throws SQLException
{
callMethod ("setTransactionIsolation",
new Class[] { Integer.TYPE },
new Object[] { new Integer(level) });
}
// JDBC 2.0
public void setTypeMap (Map typeMap)
throws SQLException
{
callMethod ("setTypeMap",
new Class[] { Map.class },
new Object[] { typeMap });
}
// This method is not required by java.sql.Connection,
// but it is used by the JDBC testcases, and is implemented
// in the public class.
public String toString ()
{
try {
return (String) connection_.callMethodReturnsObject (pxId_, "toString");
}
catch (InvocationTargetException e) {
throw ProxyClientConnection.rethrow (e);
}
}
//@pda jdbc40
protected String[] getValidWrappedList()
{
return new String[] { "java.sql.Connection" };
}
//@PDA jdbc40
/**
* Returns true if the connection has not been closed and is still valid.
* The driver shall submit a query on the connection or use some other
* mechanism that positively verifies the connection is still valid when
* this method is called.
*
* The query submitted by the driver to validate the connection shall be
* executed in the context of the current transaction.
*
* @param timeout - The time in seconds to wait for the database operation
* used to validate the connection to complete. If
* the timeout period expires before the operation
* completes, this method returns false. A value of
* 0 indicates a timeout is not applied to the
* database operation. Note that currently the timeout
* value is not used.
*
* @return true if the connection is valid, false otherwise
* @exception SQLException if a database access error occurs.
*/
public boolean isValid(int timeout) throws SQLException
{
Object[] oa = new Object[] {new Integer(timeout)};
return ((Boolean)callMethodRtnObj("isValid", new Class[] {Integer.TYPE}, oa)).booleanValue();
}
//@PDA jdbc40
/**
* Sets the value of the client info property specified by name to the
* value specified by value.
*
* Applications may use the DatabaseMetaData.getClientInfoProperties
* method to determine the client info properties supported by the driver
* and the maximum length that may be specified for each property.
*
* The driver stores the value specified in a suitable location in the
* database. For example in a special register, session parameter, or
* system table column. For efficiency the driver may defer setting the
* value in the database until the next time a statement is executed or
* prepared. Other than storing the client information in the appropriate
* place in the database, these methods shall not alter the behavior of
* the connection in anyway. The values supplied to these methods are
* used for accounting, diagnostics and debugging purposes only.
*
* The driver shall generate a warning if the client info name specified
* is not recognized by the driver.
*
* If the value specified to this method is greater than the maximum
* length for the property the driver may either truncate the value and
* generate a warning or generate a SQLException
. If the driver
* generates a SQLException
, the value specified was not set on the
* connection.
*
* The following client info properties are supported in Toobox for Java.
*
*
* - ApplicationName - The name of the application currently utilizing
* the connection
* - ClientUser - The name of the user that the application using
* the connection is performing work for. This may
* not be the same as the user name that was used
* in establishing the connection.
* - ClientHostname - The hostname of the computer the application
* using the connection is running on.
* - ClientAccounting - Client accounting information.
* - ClientProgramID - The client program identification.
*
*
* @param name The name of the client info property to set
* @param value The value to set the client info property to. If the
* value is null, the current value of the specified
* property is cleared.
*
* @throws SQLException if the database server returns an error while
* setting the client info value on the database server.
*
*/
public void setClientInfo(String name, String value)
/* ifdef JDBC40
throws SQLClientInfoException
endif */
/* ifndef JDBC40 */
throws SQLException
/* endif */
{
try
{
callMethod("setClientInfo",
new Class[] { String.class, String.class },
new Object[] { name, value });
} catch (SQLException e)
{
/* ifdef JDBC40
//may be SQLException or SQLClientInfoException
if(e instanceof SQLClientInfoException)
throw (SQLClientInfoException)e;
else
{
//HashMap m = new HashMap(); //@pdd jdbc40 merge
//@PDC jdbc40 merge. code hashmap without generic references for pre-jdk1.6
HashMap m = new HashMap();
m.put(name, ClientInfoStatus.REASON_UNKNOWN);
SQLClientInfoException clientIE = new SQLClientInfoException(e.getMessage(), e.getSQLState(), m);
throw clientIE;
}
endif */
/* ifndef JDBC40 */
throw e;
/* endif */
}
}
// @PDA 550 client info
/**
* Sets the value of the connection's client info properties. The
* Properties
object contains the names and values of the
* client info properties to be set. The set of client info properties
* contained in the properties list replaces the current set of client info
* properties on the connection. If a property that is currently set on the
* connection is not present in the properties list, that property is
* cleared. Specifying an empty properties list will clear all of the
* properties on the connection. See
* setClientInfo (String, String)
for more information.
*
* If an error occurs in setting any of the client info properties, a
* ClientInfoException
is thrown. The
* ClientInfoException
contains information indicating which
* client info properties were not set. The state of the client information
* is unknown because some databases do not allow multiple client info
* properties to be set atomically. For those databases, one or more
* properties may have been set before the error occurred.
*
* The following client info properties are supported in Toobox for Java.
*
*
* - ApplicationName - The name of the application currently utilizing
* the connection
* - ClientUser - The name of the user that the application using
* the connection is performing work for. This may
* not be the same as the user name that was used
* in establishing the connection.
* - ClientHostname - The hostname of the computer the application
* using the connection is running on.
* - ClientAccounting - Client accounting information.
* - ClientProgramID - The client program identification.
*
*
* @param properties
* the list of client info properties to set
*
* @throws SQLException
* if the database server returns an error while setting the
* clientInfo values on the database server
*
//JDBC40DOC * @see java.sql.Connection#setClientInfo(String, String)
//JDBC40DOC * setClientInfo(String, String)
*/
public void setClientInfo(Properties properties)
/* ifdef JDBC40
throws SQLClientInfoException
endif */
/* ifndef JDBC40 */
throws SQLException
/* endif */
{
try
{
callMethod ("setClientInfo",
new Class[] { Properties.class },
new Object[] { properties });
}catch(SQLException e)
{
/* ifdef JDBC40
//may be SQLException or SQLClientInfoException
if(e instanceof SQLClientInfoException)
throw (SQLClientInfoException)e;
else
{
//create Map for exception constructor
//HashMap m = new HashMap(); //@pdd jdbc40 merge
//@PDC jdbc40 merge. code hashmap without generic references for pre-jdk1.6
HashMap m = new HashMap();
Enumeration clientInfoNames = properties.keys();
while( clientInfoNames.hasMoreElements())
{
String clientInfoName = (String)clientInfoNames.nextElement();
m.put(clientInfoName, ClientInfoStatus.REASON_UNKNOWN);
}
SQLClientInfoException clientIE = new SQLClientInfoException(e.getMessage(), e.getSQLState(), m);
throw clientIE;
}
endif */
/* ifndef JDBC40 */
throw e;
/* endif */
}
}
//@PDA 550 client info
/**
* Returns the value of the client info property specified by name. This
* method may return null if the specified client info property has not
* been set and does not have a default value. This method will also
* return null if the specified client info property name is not supported
* by the driver.
*
* Applications may use the DatabaseMetaData.getClientInfoProperties
* method to determine the client info properties supported by the driver.
*
* The following client info properties are supported in Toobox for Java.
*
*
* - ApplicationName - The name of the application currently utilizing
* the connection
* - ClientUser - The name of the user that the application using
* the connection is performing work for. This may
* not be the same as the user name that was used
* in establishing the connection.
* - ClientHostname - The hostname of the computer the application
* using the connection is running on.
* - ClientAccounting - Client accounting information.
* - ClientProgramID - The client program identification.
*
*
* @param name The name of the client info property to retrieve
*
* @return The value of the client info property specified
*
* @throws SQLException if the database server returns an error when
* fetching the client info value from the database.
*
//JDBC40DOC * @see java.sql.DatabaseMetaData#getClientInfoProperties
*/
public String getClientInfo(String name) throws SQLException
{
return (String) callMethodRtnObj("getClientInfo",
new Class[] { String.class },
new Object[] { name });
}
//@PDA 550 client info
/**
* Returns a list containing the name and current value of each client info
* property supported by the driver. The value of a client info property
* may be null if the property has not been set and does not have a
* default value.
*
* The following client info properties are supported in Toobox for Java.
*
*
* - ApplicationName - The name of the application currently utilizing
* the connection
* - ClientUser - The name of the user that the application using
* the connection is performing work for. This may
* not be the same as the user name that was used
* in establishing the connection.
* - ClientHostname - The hostname of the computer the application
* using the connection is running on.
* - ClientAccounting - Client accounting information.
* - ClientProgramID - The client program identification.
*
*
* @return A Properties
object that contains the name and current value of
* each of the client info properties supported by the driver.
*
* @throws SQLException if the database server returns an error when
* fetching the client info values from the database
*/
public Properties getClientInfo() throws SQLException
{
return (Properties) callMethodRtnObj("getClientInfo");
}
//@PDA jdbc40
/**
* Constructs an object that implements the Clob
interface. The object
* returned initially contains no data. The setAsciiStream
,
* setCharacterStream
and setString
methods of
* the Clob
interface may be used to add data to the Clob
.
* @return An object that implements the Clob
interface
* @throws SQLException if an object that implements the
* Clob
interface can not be constructed.
*
*/
public Clob createClob() throws SQLException
{
return (Clob) callMethodRtnObj("createClob");
}
//@PDA jdbc40
/**
* Constructs an object that implements the Blob
interface. The object
* returned initially contains no data. The setBinaryStream
and
* setBytes
methods of the Blob
interface may be used to add data to
* the Blob
.
* @return An object that implements the Blob
interface
* @throws SQLException if an object that implements the
* Blob
interface can not be constructed
*
*/
public Blob createBlob() throws SQLException
{
return (Blob) callMethodRtnObj("createBlob");
}
//@PDA jdbc40
//JDBC40DOC /**
//JDBC40DOC * Constructs an object that implements the NClob
interface. The object
//JDBC40DOC * returned initially contains no data. The setAsciiStream
,
//JDBC40DOC * setCharacterStream
and setString
methods of the NClob
interface may
//JDBC40DOC * be used to add data to the NClob
.
//JDBC40DOC * @return An object that implements the NClob
interface
//JDBC40DOC * @throws SQLException if an object that implements the
//JDBC40DOC * NClob
interface can not be constructed.
//JDBC40DOC *
//JDBC40DOC */
/* ifdef JDBC40
public NClob createNClob() throws SQLException
{
return (NClob) callMethodRtnObj("createNClob");
}
endif */
//@PDA jdbc40
//JDBC40DOC /**
//JDBC40DOC * Constructs an object that implements the SQLXML
interface. The object
//JDBC40DOC * returned initially contains no data. The createXmlStreamWriter
object and
//JDBC40DOC * setString
method of the SQLXML
interface may be used to add data to the SQLXML
//JDBC40DOC * object.
//JDBC40DOC * @return An object that implements the SQLXML
interface
//JDBC40DOC * @throws SQLException if an object that implements the SQLXML
interface can not
//JDBC40DOC * be constructed
//JDBC40DOC */
/* ifdef JDBC40
public SQLXML createSQLXML() throws SQLException
{
return (SQLXML) callMethodRtnObj("createSQLXML");
}
endif */
//@PDA jdbc40
/**
* Factory method for creating Array objects.
*
* @param typeName the SQL name of the type the elements of the array map to. The typeName is a
* database-specific name which may be the name of a built-in type, a user-defined type or a standard SQL type supported by this database. This
* is the value returned by Array.getBaseTypeName
* @param elements the elements that populate the returned object
* @return an Array object whose elements map to the specified SQL type
* @throws SQLException if a database error occurs, the typeName is null or this method is called on a closed connection
*/
public Array createArrayOf(String typeName, Object[] elements) throws SQLException
{
return (Array) callMethodRtnObj("createArrayOf",
new Class[] { String.class, Object[].class },
new Object[] { typeName, elements });
}
//@PDA jdbc40
/**
* Factory method for creating Struct objects.
*
* @param typeName the SQL type name of the SQL structured type that this Struct
* object maps to. The typeName is the name of a user-defined type that
* has been defined for this database. It is the value returned by
* Struct.getSQLTypeName
.
* @param attributes the attributes that populate the returned object
* @return a Struct object that maps to the given SQL type and is populated with the given attributes
* @throws SQLException if a database error occurs, the typeName is null or this method is called on a closed connection
*/
public Struct createStruct(String typeName, Object[] attributes) throws SQLException
{
return (Struct) callMethodRtnObj("createStruct",
new Class[] { String.class, Object[].class },
new Object[] { typeName, attributes });
}
//@pd2 add missing proxy method. This is needed for various testcases that use jobid.
/**
Returns the job identifier of the host server job corresponding to this connection.
Every JDBC connection is associated with a host server job on the IBM i system. The
format is:
- 10 character job name
- 10 character user name
- 6 character job number
Note: Since this method is not defined in the JDBC Connection interface,
you typically need to cast a Connection object to JDConnectionProxy in order
to call this method:
String serverJobIdentifier = ((JDConnectionProxy)connection).getServerJobIdentifier();
@return The server job identifier, or null if not known.
* @throws SQLException
**/
public String getServerJobIdentifier() throws SQLException // @pd2
{ // @pd2
return (String) callMethodRtnObj("getServerJobIdentifier"); // @pd2
} // @pd2
/* ifdef JDBC40
// JDBC 4.1
public void abort(Executor executor) throws SQLException {
callMethod("abort",
new Class[] {Executor.class},
new Object[] {executor});
}
// JDBC 4.1
public void setNetworkTimeout(Executor executor, int milliseconds)
throws SQLException {
callMethod ("setNetworkTimeout",
new Class[] { Executor.class, Integer.class },
new Object[] { executor, new Integer(milliseconds) });
}
endif */
// JDBC 4.1
public int getNetworkTimeout() throws SQLException {
return ((Integer)callMethodRtnObj ("getNetworkTimeout")).intValue();
}
// JDBC 4.1
public String getSchema() throws SQLException {
return ((String)callMethodRtnObj ("getSchema"));
}
// JDBC 4.1
public void setSchema(String schema) throws SQLException {
callMethod ("setSchema",
new Class[] { String.class },
new Object[] { schema });
}
}