Class DriverAdapterCPDS
- All Implemented Interfaces:
- Serializable,- Referenceable,- ObjectFactory,- CommonDataSource,- ConnectionPoolDataSource
 An adapter for JDBC drivers that do not include an implementation of ConnectionPoolDataSource, but
 still include a DriverManager implementation. ConnectionPoolDataSources are not used
 within general applications. They are used by DataSource implementations that pool
 Connections, such as SharedPoolDataSource. A J2EE container
 will normally provide some method of initializing the ConnectionPoolDataSource whose attributes are
 presented as bean getters/setters and then deploying it via JNDI. It is then available as a source of physical
 connections to the database, when the pooling DataSource needs to create a new physical connection.
 
 Although normally used within a JNDI environment, the DriverAdapterCPDS can be instantiated and initialized as any
 bean and then attached directly to a pooling DataSource. Jdbc2PoolDataSource can use the
 ConnectionPoolDataSource with or without the use of JNDI.
 
 The DriverAdapterCPDS also provides PreparedStatement pooling which is not generally available in jdbc2
 ConnectionPoolDataSource implementation, but is addressed within the JDBC 3 specification. The
 PreparedStatement pool in DriverAdapterCPDS has been in the DBCP package for some time, but it has not
 undergone extensive testing in the configuration used here. It should be considered experimental and can be toggled
 with the poolPreparedStatements attribute.
 
 The package documentation contains an example using Apache Catalina and JNDI. The
 datasources package documentation shows how to use
 DriverAdapterCPDS as a source for Jdbc2PoolDataSource without the use of JNDI.
 
- Since:
- 2.0
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionGets the connection properties passed to the JDBC driver.Gets the value of description.Gets the driver class name.Gets the duration to sleep between runs of the idle object evictor thread.intGets the maximum time in seconds that this data source can wait while attempting to connect to a database.Gets the log writer for this data source.intGets the maximum number of statements that can remain idle in the pool, without extra ones being released, or negative for no limit.intGets the maximum number of prepared statements.Gets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any).intDeprecated.intGets the number of statements to examine during each run of the idle object evictor thread (if any.)getObjectInstance(Object refObj, Name name, Context context, Hashtable<?, ?> env) ImplementsObjectFactoryto create an instance of this classGets the value of password for the default user.char[]Gets the value of password for the default user.Attempts to establish a database connection using the default user and password.getPooledConnection(String pooledUserName, String pooledUserPassword) Attempts to establish a database connection.ImplementsReferenceable.longDeprecated.getUrl()Gets the value of connection string used to locate the database for this data source.getUser()Gets the value of default user (login or user name).booleanReturns the value of the accessToUnderlyingConnectionAllowed property.booleanWhether to toggle the pooling ofPreparedStatementsvoidsetAccessToUnderlyingConnectionAllowed(boolean allow) Sets the value of the accessToUnderlyingConnectionAllowed property.voidSets the connection properties passed to the JDBC driver.voidsetDescription(String description) Sets the value of description.voidSets the driver class name.voidsetDurationBetweenEvictionRuns(Duration durationBetweenEvictionRuns) Sets the duration to sleep between runs of the idle object evictor thread.voidsetLoginTimeout(int seconds) Sets the maximum time in seconds that this data source will wait while attempting to connect to a database.voidsetLogWriter(PrintWriter logWriter) Sets the log writer for this data source.voidsetMaxIdle(int maxIdle) Gets the maximum number of statements that can remain idle in the pool, without extra ones being released, or negative for no limit.voidsetMaxPreparedStatements(int maxPreparedStatements) Sets the maximum number of prepared statements.voidsetMinEvictableIdleDuration(Duration minEvictableIdleDuration) Sets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any).voidsetMinEvictableIdleTimeMillis(int minEvictableIdleTimeMillis) Deprecated.voidsetNumTestsPerEvictionRun(int numTestsPerEvictionRun) Sets the number of statements to examine during each run of the idle object evictor thread (if any).voidsetPassword(char[] userPassword) Sets the value of password for the default user.voidsetPassword(String userPassword) Sets the value of password for the default user.voidsetPoolPreparedStatements(boolean poolPreparedStatements) Whether to toggle the pooling ofPreparedStatementsvoidsetTimeBetweenEvictionRunsMillis(long timeBetweenEvictionRunsMillis) Deprecated.voidSets the value of URL string used to locate the database for this data source.voidSets the value of default user (login or user name).toString()Does not print the userName and userPassword field nor the 'user' or 'password' in the connectionProperties.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface javax.sql.CommonDataSourcecreateShardingKeyBuilderMethods inherited from interface javax.sql.ConnectionPoolDataSourcecreatePooledConnectionBuilder
- 
Constructor Details- 
DriverAdapterCPDSpublic DriverAdapterCPDS()Default no-argument constructor for Serialization
 
- 
- 
Method Details- 
getConnectionPropertiesGets the connection properties passed to the JDBC driver.- Returns:
- the JDBC connection properties used when creating connections.
 
- 
getDescriptionGets the value of description. This property is here for use by the code which will deploy this data source. It is not used internally.- Returns:
- value of description, may be null.
- See Also:
 
- 
getDriverGets the driver class name.- Returns:
- value of driver.
 
- 
getDurationBetweenEvictionRunsGets the duration to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.- Returns:
- the value of the evictor thread timer
- Since:
- 2.9.0
- See Also:
 
- 
getLoginTimeoutpublic int getLoginTimeout()Gets the maximum time in seconds that this data source can wait while attempting to connect to a database. NOT USED.- Specified by:
- getLoginTimeoutin interface- CommonDataSource
- Specified by:
- getLoginTimeoutin interface- ConnectionPoolDataSource
 
- 
getLogWriterGets the log writer for this data source. NOT USED.- Specified by:
- getLogWriterin interface- CommonDataSource
- Specified by:
- getLogWriterin interface- ConnectionPoolDataSource
 
- 
getMaxIdlepublic int getMaxIdle()Gets the maximum number of statements that can remain idle in the pool, without extra ones being released, or negative for no limit.- Returns:
- the value of maxIdle
 
- 
getMaxPreparedStatementspublic int getMaxPreparedStatements()Gets the maximum number of prepared statements.- Returns:
- maxPrepartedStatements value
 
- 
getMinEvictableIdleDurationGets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any).- Returns:
- the minimum amount of time a statement may sit idle in the pool.
- Since:
- 2.9.0
- See Also:
 
- 
getMinEvictableIdleTimeMillisDeprecated.Gets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any).- Returns:
- the minimum amount of time a statement may sit idle in the pool.
- See Also:
 
- 
getNumTestsPerEvictionRunpublic int getNumTestsPerEvictionRun()Gets the number of statements to examine during each run of the idle object evictor thread (if any.)- Returns:
- the number of statements to examine during each run of the idle object evictor thread (if any.)
- See Also:
 
- 
getObjectInstancepublic Object getObjectInstance(Object refObj, Name name, Context context, Hashtable<?, ?> env) throws ClassNotFoundExceptionImplementsObjectFactoryto create an instance of this class- Specified by:
- getObjectInstancein interface- ObjectFactory
- Throws:
- ClassNotFoundException
 
- 
getParentLogger- Specified by:
- getParentLoggerin interface- CommonDataSource
- Throws:
- SQLFeatureNotSupportedException
 
- 
getPasswordGets the value of password for the default user.- Returns:
- value of password.
 
- 
getPasswordCharArraypublic char[] getPasswordCharArray()Gets the value of password for the default user.- Returns:
- value of password.
- Since:
- 2.4.0
 
- 
getPooledConnectionAttempts to establish a database connection using the default user and password.- Specified by:
- getPooledConnectionin interface- ConnectionPoolDataSource
- Throws:
- SQLException
 
- 
getPooledConnectionpublic PooledConnection getPooledConnection(String pooledUserName, String pooledUserPassword) throws SQLException Attempts to establish a database connection.- Specified by:
- getPooledConnectionin interface- ConnectionPoolDataSource
- Parameters:
- pooledUserName- name to be used for the connection
- pooledUserPassword- password to be used fur the connection
- Throws:
- SQLException
 
- 
getReferenceImplementsReferenceable.- Specified by:
- getReferencein interface- Referenceable
- Throws:
- NamingException
 
- 
getTimeBetweenEvictionRunsMillisDeprecated.Gets the number of milliseconds to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.- Returns:
- the value of the evictor thread timer
- See Also:
 
- 
getUrlGets the value of connection string used to locate the database for this data source.- Returns:
- value of connection string.
 
- 
getUserGets the value of default user (login or user name).- Returns:
- value of user.
 
- 
isAccessToUnderlyingConnectionAllowedpublic boolean isAccessToUnderlyingConnectionAllowed()Returns the value of the accessToUnderlyingConnectionAllowed property.- Returns:
- true if access to the underlying is allowed, false otherwise.
 
- 
isPoolPreparedStatementspublic boolean isPoolPreparedStatements()Whether to toggle the pooling ofPreparedStatements- Returns:
- value of poolPreparedStatements.
 
- 
setAccessToUnderlyingConnectionAllowedpublic void setAccessToUnderlyingConnectionAllowed(boolean allow) Sets the value of the accessToUnderlyingConnectionAllowed property. It controls if the PoolGuard allows access to the underlying connection. (Default: false)- Parameters:
- allow- Access to the underlying connection is granted when true.
 
- 
setConnectionPropertiesSets the connection properties passed to the JDBC driver.If propscontains "user" and/or "password" properties, the corresponding instance properties are set. If these properties are not present, they are filled in usinggetUser(),getPassword()whengetPooledConnection()is called, or using the actual parameters to the method call whengetPooledConnection(String, String)is called. Calls tosetUser(String)orsetPassword(String)overwrite the values of these properties ifconnectionPropertiesis not null.- Parameters:
- props- Connection properties to use when creating new connections.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setDescriptionSets the value of description. This property is here for use by the code which will deploy this datasource. It is not used internally.- Parameters:
- description- Value to assign to description.
 
- 
setDriverSets the driver class name. Setting the driver class name cause the driver to be registered with the DriverManager.- Parameters:
- driver- Value to assign to driver.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
- ClassNotFoundException- if the class cannot be located
 
- 
setDurationBetweenEvictionRunsSets the duration to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.- Parameters:
- durationBetweenEvictionRuns- The duration to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
- Since:
- 2.9.0
- See Also:
 
- 
setLoginTimeoutpublic void setLoginTimeout(int seconds) Sets the maximum time in seconds that this data source will wait while attempting to connect to a database. NOT USED.- Specified by:
- setLoginTimeoutin interface- CommonDataSource
- Specified by:
- setLoginTimeoutin interface- ConnectionPoolDataSource
 
- 
setLogWriterSets the log writer for this data source. NOT USED.- Specified by:
- setLogWriterin interface- CommonDataSource
- Specified by:
- setLogWriterin interface- ConnectionPoolDataSource
 
- 
setMaxIdlepublic void setMaxIdle(int maxIdle) Gets the maximum number of statements that can remain idle in the pool, without extra ones being released, or negative for no limit.- Parameters:
- maxIdle- The maximum number of statements that can remain idle
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setMaxPreparedStatementspublic void setMaxPreparedStatements(int maxPreparedStatements) Sets the maximum number of prepared statements.- Parameters:
- maxPreparedStatements- the new maximum number of prepared statements
 
- 
setMinEvictableIdleDurationSets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any). When non-positive, no objects will be evicted from the pool due to idle time alone.- Parameters:
- minEvictableIdleDuration- minimum time to set in milliseconds.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called.
- Since:
- 2.9.0
- See Also:
 
- 
setMinEvictableIdleTimeMillisDeprecated.Sets the minimum amount of time a statement may sit idle in the pool before it is eligible for eviction by the idle object evictor (if any). When non-positive, no objects will be evicted from the pool due to idle time alone.- Parameters:
- minEvictableIdleTimeMillis- minimum time to set in milliseconds.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
- See Also:
 
- 
setNumTestsPerEvictionRunpublic void setNumTestsPerEvictionRun(int numTestsPerEvictionRun) Sets the number of statements to examine during each run of the idle object evictor thread (if any).When a negative value is supplied, ceil({@link BasicDataSource#getNumIdle})/abs({@link #getNumTestsPerEvictionRun})tests will be run. I.e., when the value is -n, roughly one nth of the idle objects will be tested per run.- Parameters:
- numTestsPerEvictionRun- number of statements to examine per run
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
- See Also:
 
- 
setPasswordpublic void setPassword(char[] userPassword) Sets the value of password for the default user.- Parameters:
- userPassword- Value to assign to password.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setPasswordSets the value of password for the default user.- Parameters:
- userPassword- Value to assign to password.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setPoolPreparedStatementspublic void setPoolPreparedStatements(boolean poolPreparedStatements) Whether to toggle the pooling ofPreparedStatements- Parameters:
- poolPreparedStatements- true to pool statements.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setTimeBetweenEvictionRunsMillisDeprecated.Sets the number of milliseconds to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.- Parameters:
- timeBetweenEvictionRunsMillis- The number of milliseconds to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
- See Also:
 
- 
setUrlSets the value of URL string used to locate the database for this data source.- Parameters:
- connectionString- Value to assign to connection string.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
setUserSets the value of default user (login or user name).- Parameters:
- userName- Value to assign to user.
- Throws:
- IllegalStateException- if- getPooledConnection()has been called
 
- 
toStringDoes not print the userName and userPassword field nor the 'user' or 'password' in the connectionProperties.
 
- 
getMinEvictableIdleDuration().