Interface PoolDataSource
- 
- All Superinterfaces:
- javax.sql.CommonDataSource,- javax.sql.DataSource,- Diagnosable,- java.sql.Wrapper
 - All Known Subinterfaces:
- PoolXADataSource
 - All Known Implementing Classes:
- PoolDataSourceImpl,- PoolXADataSourceImpl
 
 public interface PoolDataSource extends javax.sql.DataSource, Diagnosable A connection pool-aware data source interface.PoolDataSourceuses Universal Connection Pool internally. See setters for pool properties and their default values.The interface also defines the JNDI property names supported by UCP datasource. These properties can be configured in application servers that support datasource configuration using JNDI feature. For example, In Tomcat you can define the UCP pool JNDI resource in application's context.xml like below- <Resource name="tomcat/UCPPool" auth="Container" factory="oracle.ucp.jdbc.PoolDataSourceImpl" type="oracle.ucp.jdbc.PoolDataSource" description="UCP Pool in Tomcat" connectionFactoryClassName="oracle.jdbc.pool.OracleDataSource" user="<user>" password="<password>" initialPoolSize="<val>" url="<database_url>" />- See Also:
- UniversalConnectionPool
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Interface Description static interfacePoolDataSource.HostnameResolver
 - 
Field SummaryFields Modifier and Type Field Description static java.lang.StringSYSTEM_PROPERTY_AFFINITY_STRICTStrict RAC affinity flag.static java.lang.StringSYSTEM_PROPERTY_BEGIN_REQUEST_AT_CONNECTION_CREATIONDriver's implicit beginRequest switch.static java.lang.StringSYSTEM_PROPERTY_CONNECTION_CREATION_RETRY_DELAYThe retry delay for connection creation polling.static java.lang.StringSYSTEM_PROPERTY_CREATE_CONNECTION_IN_BORROW_THREADSince 23.4, for backward compatibility: there are two modes to grow a pool.static java.lang.StringSYSTEM_PROPERTY_DESTROY_ON_RELOADWhat to do if a new pool with existing pool name gets created.static java.lang.StringSYSTEM_PROPERTY_DIAGNOSTIC_BUFFER_SIZEDiagnosability: initial in-memory trace size.static java.lang.StringSYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_LOGGINGDiagnosability: is debug logging enabled?static java.lang.StringSYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_TRACEDiagnosability: is tracing enabled?static java.lang.StringSYSTEM_PROPERTY_DIAGNOSTIC_ERROR_CODES_TO_WATCH_LISTDiagnosability: error codes to watch and trigger dumping in-memory tracing buffer into a logger.static java.lang.StringSYSTEM_PROPERTY_DIAGNOSTIC_LOGGING_LEVELDiagnosability: initial logging level.static java.lang.StringSYSTEM_PROPERTY_ENABLE_SHUTDOWN_HOOKThe shutdown hook of UCP will attempt to gracefully close connections during shutdown by first closing available connections in the pool and then continuously retrying until, eventually, all connections are closed.static java.lang.StringSYSTEM_PROPERTY_FAN_ENABLEDDriver's High Availability processing switch.static java.lang.StringSYSTEM_PROPERTY_IMITATE_ASYNC_BORROWAsynchronous borrow imitation switch.static java.lang.StringSYSTEM_PROPERTY_MAX_INIT_THREADSThe maximum number of worker threads to reach initial pool size.static java.lang.StringSYSTEM_PROPERTY_PRE_WLS1212_COMPATIBLEPre-WLS 12.1.2 compatibility flag.static java.lang.StringSYSTEM_PROPERTY_RLB_INOPERABILITY_TIMEOUTTimeout in seconds for the UCP Runtime Load Balancer to be allowed not to follow RLB advisories in case of inoperability of at least one RAC instance (i.e.static java.lang.StringSYSTEM_PROPERTY_SELFTUNINGPool Size self-tuning switch.static java.lang.StringSYSTEM_PROPERTY_TIMERS_AFFECT_ALL_CONNECTIONSThe switch to change the logic of InactiveConnectionTimeout and MaxConnectionReuseTime handling.static java.lang.StringSYSTEM_PROPERTY_WLS_JTAUCP native data source in WebLogic to work with WLS transaction manager for JTA/XA transactions.static java.lang.StringSYSTEM_PROPERTY_XML_CONFIG_FILEThe XML configuration file path for UCP.static java.lang.StringUCP_ABANDONED_CONNECTION_TIMEOUTstatic java.lang.StringUCP_COMMIT_ON_CONNECTION_RETURNstatic java.lang.StringUCP_CONNECTION_AFFINITY_CALLBACKstatic java.lang.StringUCP_CONNECTION_CREATION_CONSUMERstatic java.lang.StringUCP_CONNECTION_FACTORY_CLASS_NAMEstatic java.lang.StringUCP_CONNECTION_FACTORY_PROPERTIESstatic java.lang.StringUCP_CONNECTION_HARVEST_MAX_COUNTstatic java.lang.StringUCP_CONNECTION_HARVEST_TRIGGER_COUNTstatic java.lang.StringUCP_CONNECTION_INITIALIZATION_CALLBACKstatic java.lang.StringUCP_CONNECTION_LABELING_CALLBACKstatic java.lang.StringUCP_CONNECTION_LABELING_HIGH_COSTstatic java.lang.StringUCP_CONNECTION_POOL_NAMEstatic java.lang.StringUCP_CONNECTION_PROPERTIESstatic java.lang.StringUCP_CONNECTION_REPURPOSE_THRESHOLDstatic java.lang.StringUCP_CONNECTION_VALIDATION_TIMEOUTstatic java.lang.StringUCP_CONNECTION_WAIT_DURATIONstatic java.lang.StringUCP_CONNECTION_WAIT_TIMEOUTstatic java.lang.StringUCP_CREATE_CONNECTION_IN_BORROW_THREADstatic java.lang.StringUCP_DATA_SOURCE_FROM_CONFIGURATIONstatic java.lang.StringUCP_DATA_SOURCE_NAMEstatic java.lang.StringUCP_DATABASE_NAMEstatic java.lang.StringUCP_DESCRIPTIONstatic java.lang.StringUCP_FAST_CONNECTION_FAILOVER_ENABLEDstatic java.lang.StringUCP_HIGH_COST_CONNECTION_REUSE_THRESHOLDstatic java.lang.StringUCP_INACTIVE_CONNECTION_TIMEOUTstatic java.lang.StringUCP_INITIAL_POOL_SIZEstatic java.lang.StringUCP_LOGIN_TIMEOUTstatic java.lang.StringUCP_MAX_CONNECTION_REUSE_COUNTstatic java.lang.StringUCP_MAX_CONNECTION_REUSE_TIMEstatic java.lang.StringUCP_MAX_CONNECTIONS_PER_SERVICEstatic java.lang.StringUCP_MAX_CONNECTIONS_PER_SHARDstatic java.lang.StringUCP_MAX_IDLE_TIMEstatic java.lang.StringUCP_MAX_POOL_SIZEstatic java.lang.StringUCP_MAX_STATEMENTSstatic java.lang.StringUCP_MIN_IDLEstatic java.lang.StringUCP_MIN_POOL_SIZEstatic java.lang.StringUCP_NETWORK_PROTOCOLstatic java.lang.StringUCP_NTH_RETURNED_CONNECTION_TO_VALIDATEstatic java.lang.StringUCP_ONS_CONFIGURATIONstatic java.lang.StringUCP_PASSWORDstatic java.lang.StringUCP_PDB_ROLESstatic java.lang.StringUCP_PORT_NUMBERstatic java.lang.StringUCP_PROPERTY_CYCLEstatic java.lang.StringUCP_READONLY_INSTANCE_ALLOWEDstatic java.lang.StringUCP_ROLE_NAMEstatic java.lang.StringUCP_SECONDS_TO_TRUST_IDLE_CONNECTIONstatic java.lang.StringUCP_SERVER_NAMEstatic java.lang.StringUCP_SERVICE_NAMEstatic java.lang.StringUCP_SHARDING_MODEstatic java.lang.StringUCP_SQL_FOR_VALIDATE_CONNECTIONstatic java.lang.StringUCP_TIME_TO_LIVE_CONNECTION_TIMEOUTstatic java.lang.StringUCP_TIMEOUT_CHECK_INTERVALstatic java.lang.StringUCP_URLstatic java.lang.StringUCP_USERstatic java.lang.StringUCP_VALIDATE_CONNECTION_ON_BORROW
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Deprecated Methods Modifier and Type Method Description UCPConnectionBuildercreateConnectionBuilder()Creates a new UCPConnectionBuilder instance.default oracle.jdbc.OracleShardingKeyBuildercreateShardingKeyBuilder()Creates a new OracleShardingKeyBuilder instanceintgetAbandonedConnectionTimeout()Gets the abandoned connection timeout value.intgetAvailableConnectionsCount()Gets the number of available connections in the pool.intgetBorrowedConnectionsCount()Gets the number of borrowed connections from the pool.java.sql.ConnectiongetConnection(java.lang.String username, java.lang.String password, java.util.Properties labels)Attempts to obtain a database connection with the requested connection labels.java.sql.ConnectiongetConnection(java.util.Properties labels)Attempts to obtain a database connection with the requested connection labels.default java.util.function.Consumer<oracle.ucp.ConnectionCreationInformation>getConnectionCreationConsumer()Obtains the registered connection creation Consumer, if any.java.lang.StringgetConnectionFactoryClassName()Gets the Connection Factory class name.java.util.PropertiesgetConnectionFactoryProperties()Gets the connection factory properties that are set on this data source.java.lang.StringgetConnectionFactoryProperty(java.lang.String propertyName)Gets the specified connection factory property that are set on this data source.intgetConnectionHarvestMaxCount()Gets the maximum number of connections that may be harvested when the connection harvesting occurs.intgetConnectionHarvestTriggerCount()Gets the number of available connections below which the connection pool's connection harvesting will occur.ConnectionInitializationCallbackgetConnectionInitializationCallback()Obtains the registered connection initialization callback, if any.intgetConnectionLabelingHighCost()Obtains the cost value which identifies a connection as "high-cost" for connection labeling.java.lang.StringgetConnectionPoolName()Gets the connection pool name.java.util.PropertiesgetConnectionProperties()Gets the connection properties that are set on this data source.java.lang.StringgetConnectionProperty(java.lang.String propertyName)Gets the specified connection property that are set on this data source.intgetConnectionRepurposeThreshold()Gets the connection repurpose threshold for the pool.intgetConnectionValidationTimeout()Connection validation timeout getterjava.time.DurationgetConnectionWaitDuration()Gets the maximum time (in seconds) that any connection borrow request can wait before it returns to the application.intgetConnectionWaitTimeout()Deprecated.java.lang.StringgetDatabaseName()Gets the database name.java.lang.StringgetDataSourceName()Gets the data source name.java.lang.StringgetDescription()Gets the data source description.booleangetFastConnectionFailoverEnabled()Checks if Fast Connection Failover is enabled.intgetHighCostConnectionReuseThreshold()Obtains the high-cost connection reuse threshold property value for connection labeling.intgetInactiveConnectionTimeout()Gets the inactive connection timeout.intgetInitialPoolSize()Gets the initial pool size.intgetMaxConnectionReuseCount()Gets the maximum connection reuse count property value.longgetMaxConnectionReuseTime()Gets the maximum connection reuse time property value.intgetMaxConnectionsPerService()Gets the maximum number of connections that can be obtained to a particular service, in a shared pool.intgetMaxConnectionsPerShard()Gets the currently configured max connections that can be created per shard from this connection pool.intgetMaxIdleTime()Gets the maximum idle time.intgetMaxPoolSize()Gets the maximum number of connections that the connection pool will maintain.intgetMaxStatements()Gets the maximum number of statements that may be pooled or cached on a Connection.intgetMinIdle()Gets the minimum number of idle connections that the connection pool will maintain.intgetMinPoolSize()Gets the minimum number of connections that the connection pool will maintain.java.lang.StringgetNetworkProtocol()Gets the data source network protocol.java.lang.StringgetONSConfiguration()Returns the ONS configuration string that is used for remote ONS subscription in the form specified insetONSConfiguration(String).default java.lang.StringgetPassword()Deprecated.java.util.PropertiesgetPdbRoles()Gets the PDB roles specified for this datasourceintgetPortNumber()Gets the database port number.intgetPropertyCycle()Gets the property cycle in seconds.intgetQueryTimeout()Gets the number of seconds the driver will wait for a Statement object to execute to the given number of seconds.java.lang.StringgetRoleName()Gets the data source role name.intgetSecondsToTrustIdleConnection()Gets the seconds To Trust Idle Connection value.java.lang.StringgetServerName()Gets the database server name.java.lang.StringgetServiceName()Gets the service name set on this data sourcebooleangetShardingMode()Returns the mode of UCP when UCP is using a Sharded Database.java.lang.StringgetSQLForValidateConnection()Gets the value of theSQLForValidateConnectionproperty.JDBCConnectionPoolStatisticsgetStatistics()Gets the statistics of the connection pool.intgetTimeoutCheckInterval()Gets the timeout check interval (in seconds).intgetTimeToLiveConnectionTimeout()Gets the maximum time (in seconds) a connection may remain in-use.java.lang.StringgetURL()Gets the URL for this data source.java.lang.StringgetUser()Gets the user name for this data source.booleangetValidateConnectionOnBorrow()Returns whether or not a connection being borrowed should first be validated.booleanisCommitOnConnectionReturn()Returns the boolean value for the property that controls the behavior of UCP when a connection is released back to the pool with pending uncommitted changes in an active transaction.booleanisCreateConnectionInBorrowThread()Returns the connection creation mode: either "true" if connections are created using the borrowing thread, or "false" if connections are created in the background (the default).booleanisReadOnlyInstanceAllowed()Returns true if the connection borrow is allowed to a read-only instance, false otherwise.voidreconfigureDataSource(java.util.Properties configuration)Reconfigures the data source.voidregisterConnectionAffinityCallback(ConnectionAffinityCallback cbk)Registers a connection affinity callback on the connection pool.default voidregisterConnectionCreationConsumer(java.util.function.Consumer<oracle.ucp.ConnectionCreationInformation> consumer)Registers a connection creation Consumer.voidregisterConnectionInitializationCallback(ConnectionInitializationCallback cbk)Registers a connection initialization callback.voidregisterConnectionLabelingCallback(ConnectionLabelingCallback cbk)Registers a connection labeling callback with the underlying connection pool.voidremoveConnectionAffinityCallback()Removes theConnectionAffinityCallbackobject registered on the connection pool.voidremoveConnectionLabelingCallback()Removes theConnectionLabelingCallbackobject registered with the underlying connection pool, if any.voidsetAbandonedConnectionTimeout(int abandonedConnectionTimeout)Sets the abandoned connection timeout.voidsetCommitOnConnectionReturn(boolean commit)Sets the boolean value for the property that controls the behavior of UCP when a connection is released back to the pool with pending uncommitted changes in an active transaction.voidsetConnectionFactoryClassName(java.lang.String factoryClassName)Sets the Connection Factory class name.voidsetConnectionFactoryProperties(java.util.Properties factoryProperties)Sets the connection factory properties on the connection factory.voidsetConnectionFactoryProperty(java.lang.String name, java.lang.String value)Sets a connection factory property on the connection factory.voidsetConnectionHarvestMaxCount(int connectionHarvestMaxCount)Sets the maximum number of connections that may be harvested when the connection harvesting occurs.voidsetConnectionHarvestTriggerCount(int connectionHarvestTriggerCount)Sets the number of available connections below which the connection pool's connection harvesting will occur.voidsetConnectionLabelingHighCost(int highCost)Sets the cost value which identifies a connection as "high-cost" for connection labeling.voidsetConnectionPoolName(java.lang.String connectionpoolName)Sets the connection pool name.voidsetConnectionProperties(java.util.Properties connectionProperties)Sets the connection properties on the connection factory.voidsetConnectionProperty(java.lang.String name, java.lang.String value)Sets a connection property on the connection factory.voidsetConnectionRepurposeThreshold(int threshold)Sets the connection repurpose threshold for the pool.voidsetConnectionValidationTimeout(int connectionValidationTimeout)This property changes the connection validation timeout which is specified in seconds.voidsetConnectionWaitDuration(java.time.Duration waitDuration)Configures how much time a connection request call may wait before it either successfully returns a connection or throws an exception.voidsetConnectionWaitTimeout(int waitTimeout)Deprecated.voidsetCreateConnectionInBorrowThread(boolean createConnectionInBorrowThread)Set this flag to true to make UCP use the borrowing thread to create new connections.voidsetDatabaseName(java.lang.String databaseName)Sets the database name.voidsetDataSourceName(java.lang.String dataSourceName)Sets the data source name.voidsetDescription(java.lang.String description)Sets the data source description.voidsetFastConnectionFailoverEnabled(boolean failoverEnabled)Enables Fast Connection Failover (FCF) for the connection pool accessed using this pool-enabled data source.voidsetHighCostConnectionReuseThreshold(int threshold)Sets the high-cost connection reuse threshold for connection labeling.voidsetHostnameResolver(PoolDataSource.HostnameResolver hostnameResolver)Specifies aPoolDataSource.HostnameResolverto use by the poolvoidsetInactiveConnectionTimeout(int inactivityTimeout)Sets the inactive connection timeout.voidsetInitialPoolSize(int initialPoolSize)Sets the initial pool size.voidsetMaxConnectionReuseCount(int maxConnectionReuseCount)Sets the maximum connection reuse count property.voidsetMaxConnectionReuseTime(long maxConnectionReuseTime)Sets the maximum connection reuse time property.voidsetMaxConnectionsPerShard(int maxConnectionsPerShard)Sets the max number of connections that can be created per shard from this connection pool.voidsetMaxIdleTime(int idleTime)Sets the maximum idle time for available connections in the pool.voidsetMaxPoolSize(int maxPoolSize)Sets the maximum number of connections.voidsetMaxStatements(int maxStatements)Sets the maximum number of statements that may be pooled or cached on a connection.voidsetMinIdle(int minIdle)Sets the minimum number of idle connections.voidsetMinPoolSize(int minPoolSize)Sets the minimum number of connections.voidsetNetworkProtocol(java.lang.String networkProtocol)Sets the data source network protocol.voidsetONSConfiguration(java.lang.String onsConfigStr)Sets the configuration string used for remote ONS subscription.voidsetPassword(java.lang.String pd)Sets the password with which connections have to be obtained.voidsetPortNumber(int portNumber)Sets the database port number.voidsetPropertyCycle(int propertyCycle)Sets the property cycle in seconds.voidsetQueryTimeout(int queryTimeout)Sets the number of seconds the driver will wait for a Statement object to execute to the given number of seconds.voidsetReadOnlyInstanceAllowed(boolean readOnlyInstanceAllowed)Sets the read-only instance allowed value on the datasource.voidsetRoleName(java.lang.String roleName)Sets the data source role name.voidsetSecondsToTrustIdleConnection(int secondsToTrustIdleConnection)Sets the time in seconds to trust an idle connection to skip a validation test.voidsetServerName(java.lang.String serverName)Sets the database server name.voidsetShardingMode(boolean shardingMode)This API changes the mode of UCP when UCP is using a Sharded Database.voidsetSQLForValidateConnection(java.lang.String SQLString)Sets the value of theSQLForValidateConnectionproperty.voidsetSSLContext(javax.net.ssl.SSLContext sslContext)Specifies aSSLContextto use as a factory for SSLEngine objects that carry out the TLS protocol.voidsetTimeoutCheckInterval(int timeInterval)Sets the timeoutCheckInterval (in seconds).voidsetTimeToLiveConnectionTimeout(int timeToLiveConnectionTimeout)Sets the maximum time (in seconds) a connection may remain in-use.voidsetTokenSupplier(java.util.function.Supplier<? extends oracle.jdbc.AccessToken> tokenSupplier)Sets a supplier function that generates an access token when creating a connection with thisDataSource.voidsetURL(java.lang.String url)Sets the URL that the data source uses to obtain connections to the database.voidsetUser(java.lang.String userName)Sets the user name with which connections have to be obtained.voidsetValidateConnectionOnBorrow(boolean validateConnectionOnBorrow)Makes the pool validate the connection before returning it to the user by calling the JDBC API "isValid".default voidunregisterConnectionCreationConsumer()Unregisters the connection creation Consumer on this pool.voidunregisterConnectionInitializationCallback()Unregisters the connection initialization callback on this pool.- 
Methods inherited from interface javax.sql.DataSourcegetConnection, getConnection, getLoginTimeout, getLogWriter, setLoginTimeout, setLogWriter
 - 
Methods inherited from interface oracle.ucp.diagnostics.DiagnosablebeginCurrentSql, debug, debug, endCurrentSql, format, getDiagnosable, isLoggingLevelFinest, resumeLogging, secure, suspendLogging, trace, trace
 
- 
 
- 
- 
- 
Field Detail- 
SYSTEM_PROPERTY_AFFINITY_STRICTstatic final java.lang.String SYSTEM_PROPERTY_AFFINITY_STRICT Strict RAC affinity flag.This system property indicates whether RAC affinity is strict or not. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_MAX_INIT_THREADSstatic final java.lang.String SYSTEM_PROPERTY_MAX_INIT_THREADS The maximum number of worker threads to reach initial pool size.This system property defines how many worker threads will perticipate in connection pool warming up creating designated number of initial connections. The default value is 4. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_PRE_WLS1212_COMPATIBLEstatic final java.lang.String SYSTEM_PROPERTY_PRE_WLS1212_COMPATIBLE Pre-WLS 12.1.2 compatibility flag.This system property defines whether we should operate in pre-WLS 12.1.2 compatible mode or not. If the property value is "true", we'll be backward-compatible with WLS 10.3.6 and 12.1.1. This is a transient property that will be removed in a future version/patch. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_CONNECTION_CREATION_RETRY_DELAYstatic final java.lang.String SYSTEM_PROPERTY_CONNECTION_CREATION_RETRY_DELAY The retry delay for connection creation polling.When a database is inoperable, UCP makes periodic connection creation reattempts. This system property defined the re-attempt timeout in milliseconds. The default value is 3000 milliseconds. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_FAN_ENABLEDstatic final java.lang.String SYSTEM_PROPERTY_FAN_ENABLED Driver's High Availability processing switch.This system property is the flag for disabling Oracle JDBC driver's High Availability processing. This applies to both UCP and WLS AGL use cases. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_BEGIN_REQUEST_AT_CONNECTION_CREATIONstatic final java.lang.String SYSTEM_PROPERTY_BEGIN_REQUEST_AT_CONNECTION_CREATION Driver's implicit beginRequest switch.This system property is the flag for disabling Oracle JDBC driver's implicit beginRequest for Auto-AC (Automatic Application Continuity). This applies to both UCP and WLS AGL use cases. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_XML_CONFIG_FILEstatic final java.lang.String SYSTEM_PROPERTY_XML_CONFIG_FILE The XML configuration file path for UCP.This system property defines the pathname for an XML file to read and interpret for automatic UCP configuring. No default value (empty string). - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DESTROY_ON_RELOADstatic final java.lang.String SYSTEM_PROPERTY_DESTROY_ON_RELOAD What to do if a new pool with existing pool name gets created.This system property is the flag instructing whether to destroy a pool or throw the "pool already exists" exception if there is an attempt to create a new pool with the name of existing pool. This feature has been implemented per JBoss request because thir reload procedure recreates a pool with the same name expecting the old one is implicitly gets destroyed. The traditional pool's behavior in this case is to throw the exception. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_IMITATE_ASYNC_BORROWstatic final java.lang.String SYSTEM_PROPERTY_IMITATE_ASYNC_BORROW Asynchronous borrow imitation switch.This system property is the flag defining whether to run real asynchronous borrow mechanism or its imitation through blocking borrow. This property is introduced for debugging and testing purposes. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_SELFTUNINGstatic final java.lang.String SYSTEM_PROPERTY_SELFTUNING Pool Size self-tuning switch.This system property is the flag to enable or disable pool size self-tuning. If self-tuning is enabled, UCP will try to keep pool's working set of connection to be able to effectively serve recent number of connection borrow requests. Self-tuning mechanism will not bring the working set of connections beyond designated pool bounds (minumum and maximum pool size). The default value is "false", i.e. self-tuning is disabled. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_WLS_JTAstatic final java.lang.String SYSTEM_PROPERTY_WLS_JTA UCP native data source in WebLogic to work with WLS transaction manager for JTA/XA transactions.This system property is the flag that allows UCP native data source in WebLogic to work with WLS transaction manager for JTA/XA transactions. The feature is disabled by default, and can be enabled by setting the system property to true. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_TIMERS_AFFECT_ALL_CONNECTIONSstatic final java.lang.String SYSTEM_PROPERTY_TIMERS_AFFECT_ALL_CONNECTIONS The switch to change the logic of InactiveConnectionTimeout and MaxConnectionReuseTime handling.This system property changes the behavior of InactiveConnectionTimeout and MaxConnectionReuseTime: if set to false, a pool will be reduced down to minPoolSize, other connections, even if applicable, will be left opened and not replaced. If set to false and the number of idle connections is equal to the min pool size, then these timeouts are ignored. If set to true, the timeouts are enforced and will affect connections even if the number of idle connections is smaller than the min pool size. This will cause idle connections to be purged and re-created. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_TRACEstatic final java.lang.String SYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_TRACE Diagnosability: is tracing enabled?This system property is the flag for enabling diagnosability tracing. Initial state for a flag allowing publishing a trace into DiagnosticsCollector's memory handlers. Tracing in this context is a collecting logging messages into an in-memory ring buffer. The default value is "true". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_LOGGINGstatic final java.lang.String SYSTEM_PROPERTY_DIAGNOSTIC_ENABLE_LOGGING Diagnosability: is debug logging enabled?Initial state for a flag allowing publishing a trace into DiagnosticsCollector's debug logger. Logging is the same as the Java logging API. The default value is "false". - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DIAGNOSTIC_BUFFER_SIZEstatic final java.lang.String SYSTEM_PROPERTY_DIAGNOSTIC_BUFFER_SIZE Diagnosability: initial in-memory trace size.Initial size of a Diagnosability in-memory tracing buffers. The default value is 1024 log messages. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DIAGNOSTIC_LOGGING_LEVELstatic final java.lang.String SYSTEM_PROPERTY_DIAGNOSTIC_LOGGING_LEVEL Diagnosability: initial logging level.This system property defines the default logging level for all loggers. Every logger, if not explicitly leveled in the logging config file, will be leveled with this level. The default value is Level.INFO. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_DIAGNOSTIC_ERROR_CODES_TO_WATCH_LISTstatic final java.lang.String SYSTEM_PROPERTY_DIAGNOSTIC_ERROR_CODES_TO_WATCH_LIST Diagnosability: error codes to watch and trigger dumping in-memory tracing buffer into a logger.This system property defined the comma separated list of SQLException and UniversalConnectionPoolException error codes to trigger in-memory buffer dump into an appropriate logger. The default value is empty list, nothing. - See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_ENABLE_SHUTDOWN_HOOKstatic final java.lang.String SYSTEM_PROPERTY_ENABLE_SHUTDOWN_HOOK The shutdown hook of UCP will attempt to gracefully close connections during shutdown by first closing available connections in the pool and then continuously retrying until, eventually, all connections are closed. Note that any pending transaction will be rolled back. This shutdown hook is enabled by default, but can be disabled by setting this system property to false.-Doracle.ucp.enableShutdownHook=false- See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_RLB_INOPERABILITY_TIMEOUTstatic final java.lang.String SYSTEM_PROPERTY_RLB_INOPERABILITY_TIMEOUT Timeout in seconds for the UCP Runtime Load Balancer to be allowed not to follow RLB advisories in case of inoperability of at least one RAC instance (i.e. if an instance is UP but throws SQLRecoverableException on an attempt to create a connection on it).- See Also:
- Constant Field Values
 
 - 
SYSTEM_PROPERTY_CREATE_CONNECTION_IN_BORROW_THREADstatic final java.lang.String SYSTEM_PROPERTY_CREATE_CONNECTION_IN_BORROW_THREAD Since 23.4, for backward compatibility: there are two modes to grow a pool. If set to true, pool grows with a borrow thread. If set to false, pool grows with a background executor. This property is "false" by default. This setting can be overridden by the following property: setCreateConnectionInBorrowThread(boolean). for an apropriate PoolDataSource's object.If this property is set to false, a pool waits no longer than a designated connection wait duration no matter how long it takes to create a new connection to grow a pool, if no connection is available at this moment. If this property is set to true, then in this backward compatibility mode a pool waits for a connection to be synchronously created in a borrow thread, and the waiting time can take longer than connectionWaitDuration. For connectionWaitDuration please refer to setConnectionWaitDuration(java.time.Duration).- See Also:
- Constant Field Values
 
 - 
UCP_USERstatic final java.lang.String UCP_USER - See Also:
- Constant Field Values
 
 - 
UCP_URLstatic final java.lang.String UCP_URL - See Also:
- Constant Field Values
 
 - 
UCP_PASSWORDstatic final java.lang.String UCP_PASSWORD - See Also:
- Constant Field Values
 
 - 
UCP_SERVER_NAMEstatic final java.lang.String UCP_SERVER_NAME - See Also:
- Constant Field Values
 
 - 
UCP_PORT_NUMBERstatic final java.lang.String UCP_PORT_NUMBER - See Also:
- Constant Field Values
 
 - 
UCP_DATABASE_NAMEstatic final java.lang.String UCP_DATABASE_NAME - See Also:
- Constant Field Values
 
 - 
UCP_DATA_SOURCE_NAMEstatic final java.lang.String UCP_DATA_SOURCE_NAME - See Also:
- Constant Field Values
 
 - 
UCP_DESCRIPTIONstatic final java.lang.String UCP_DESCRIPTION - See Also:
- Constant Field Values
 
 - 
UCP_NETWORK_PROTOCOLstatic final java.lang.String UCP_NETWORK_PROTOCOL - See Also:
- Constant Field Values
 
 - 
UCP_ROLE_NAMEstatic final java.lang.String UCP_ROLE_NAME - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_FACTORY_CLASS_NAMEstatic final java.lang.String UCP_CONNECTION_FACTORY_CLASS_NAME - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_PROPERTIESstatic final java.lang.String UCP_CONNECTION_PROPERTIES - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_FACTORY_PROPERTIESstatic final java.lang.String UCP_CONNECTION_FACTORY_PROPERTIES - See Also:
- Constant Field Values
 
 - 
UCP_VALIDATE_CONNECTION_ON_BORROWstatic final java.lang.String UCP_VALIDATE_CONNECTION_ON_BORROW - See Also:
- Constant Field Values
 
 - 
UCP_SQL_FOR_VALIDATE_CONNECTIONstatic final java.lang.String UCP_SQL_FOR_VALIDATE_CONNECTION - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_POOL_NAMEstatic final java.lang.String UCP_CONNECTION_POOL_NAME - See Also:
- Constant Field Values
 
 - 
UCP_INITIAL_POOL_SIZEstatic final java.lang.String UCP_INITIAL_POOL_SIZE - See Also:
- Constant Field Values
 
 - 
UCP_MIN_POOL_SIZEstatic final java.lang.String UCP_MIN_POOL_SIZE - See Also:
- Constant Field Values
 
 - 
UCP_MIN_IDLEstatic final java.lang.String UCP_MIN_IDLE - See Also:
- Constant Field Values
 
 - 
UCP_MAX_POOL_SIZEstatic final java.lang.String UCP_MAX_POOL_SIZE - See Also:
- Constant Field Values
 
 - 
UCP_NTH_RETURNED_CONNECTION_TO_VALIDATEstatic final java.lang.String UCP_NTH_RETURNED_CONNECTION_TO_VALIDATE - See Also:
- Constant Field Values
 
 - 
UCP_ABANDONED_CONNECTION_TIMEOUTstatic final java.lang.String UCP_ABANDONED_CONNECTION_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_TIME_TO_LIVE_CONNECTION_TIMEOUTstatic final java.lang.String UCP_TIME_TO_LIVE_CONNECTION_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_INACTIVE_CONNECTION_TIMEOUTstatic final java.lang.String UCP_INACTIVE_CONNECTION_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_MAX_IDLE_TIMEstatic final java.lang.String UCP_MAX_IDLE_TIME - See Also:
- Constant Field Values
 
 - 
UCP_TIMEOUT_CHECK_INTERVALstatic final java.lang.String UCP_TIMEOUT_CHECK_INTERVAL - See Also:
- Constant Field Values
 
 - 
UCP_PROPERTY_CYCLEstatic final java.lang.String UCP_PROPERTY_CYCLE - See Also:
- Constant Field Values
 
 - 
UCP_MAX_STATEMENTSstatic final java.lang.String UCP_MAX_STATEMENTS - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_WAIT_TIMEOUTstatic final java.lang.String UCP_CONNECTION_WAIT_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_WAIT_DURATIONstatic final java.lang.String UCP_CONNECTION_WAIT_DURATION - See Also:
- Constant Field Values
 
 - 
UCP_MAX_CONNECTION_REUSE_TIMEstatic final java.lang.String UCP_MAX_CONNECTION_REUSE_TIME - See Also:
- Constant Field Values
 
 - 
UCP_MAX_CONNECTION_REUSE_COUNTstatic final java.lang.String UCP_MAX_CONNECTION_REUSE_COUNT - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_HARVEST_TRIGGER_COUNTstatic final java.lang.String UCP_CONNECTION_HARVEST_TRIGGER_COUNT - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_HARVEST_MAX_COUNTstatic final java.lang.String UCP_CONNECTION_HARVEST_MAX_COUNT - See Also:
- Constant Field Values
 
 - 
UCP_FAST_CONNECTION_FAILOVER_ENABLEDstatic final java.lang.String UCP_FAST_CONNECTION_FAILOVER_ENABLED - See Also:
- Constant Field Values
 
 - 
UCP_ONS_CONFIGURATIONstatic final java.lang.String UCP_ONS_CONFIGURATION - See Also:
- Constant Field Values
 
 - 
UCP_SECONDS_TO_TRUST_IDLE_CONNECTIONstatic final java.lang.String UCP_SECONDS_TO_TRUST_IDLE_CONNECTION - See Also:
- Constant Field Values
 
 - 
UCP_MAX_CONNECTIONS_PER_SERVICEstatic final java.lang.String UCP_MAX_CONNECTIONS_PER_SERVICE - See Also:
- Constant Field Values
 
 - 
UCP_LOGIN_TIMEOUTstatic final java.lang.String UCP_LOGIN_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_SERVICE_NAMEstatic final java.lang.String UCP_SERVICE_NAME - See Also:
- Constant Field Values
 
 - 
UCP_PDB_ROLESstatic final java.lang.String UCP_PDB_ROLES - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_AFFINITY_CALLBACKstatic final java.lang.String UCP_CONNECTION_AFFINITY_CALLBACK - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_INITIALIZATION_CALLBACKstatic final java.lang.String UCP_CONNECTION_INITIALIZATION_CALLBACK - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_CREATION_CONSUMERstatic final java.lang.String UCP_CONNECTION_CREATION_CONSUMER - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_LABELING_CALLBACKstatic final java.lang.String UCP_CONNECTION_LABELING_CALLBACK - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_LABELING_HIGH_COSTstatic final java.lang.String UCP_CONNECTION_LABELING_HIGH_COST - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_REPURPOSE_THRESHOLDstatic final java.lang.String UCP_CONNECTION_REPURPOSE_THRESHOLD - See Also:
- Constant Field Values
 
 - 
UCP_HIGH_COST_CONNECTION_REUSE_THRESHOLDstatic final java.lang.String UCP_HIGH_COST_CONNECTION_REUSE_THRESHOLD - See Also:
- Constant Field Values
 
 - 
UCP_DATA_SOURCE_FROM_CONFIGURATIONstatic final java.lang.String UCP_DATA_SOURCE_FROM_CONFIGURATION - See Also:
- Constant Field Values
 
 - 
UCP_MAX_CONNECTIONS_PER_SHARDstatic final java.lang.String UCP_MAX_CONNECTIONS_PER_SHARD - See Also:
- Constant Field Values
 
 - 
UCP_SHARDING_MODEstatic final java.lang.String UCP_SHARDING_MODE - See Also:
- Constant Field Values
 
 - 
UCP_CONNECTION_VALIDATION_TIMEOUTstatic final java.lang.String UCP_CONNECTION_VALIDATION_TIMEOUT - See Also:
- Constant Field Values
 
 - 
UCP_READONLY_INSTANCE_ALLOWEDstatic final java.lang.String UCP_READONLY_INSTANCE_ALLOWED - See Also:
- Constant Field Values
 
 - 
UCP_CREATE_CONNECTION_IN_BORROW_THREADstatic final java.lang.String UCP_CREATE_CONNECTION_IN_BORROW_THREAD - See Also:
- Constant Field Values
 
 - 
UCP_COMMIT_ON_CONNECTION_RETURNstatic final java.lang.String UCP_COMMIT_ON_CONNECTION_RETURN - See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
getInitialPoolSizeint getInitialPoolSize() Gets the initial pool size.- Returns:
- the initial pool size.
 
 - 
setInitialPoolSizevoid setInitialPoolSize(int initialPoolSize) throws java.sql.SQLExceptionSets the initial pool size. This is the number of connections that will be created and placed in the pool when the pool is started.The range of valid values is 0 to Integer.MAX_VALUE. It is illegal to set this to a value greater than the maximum pool size. Defaults to 0.- Parameters:
- initialPoolSize- the initial pool size.
- Throws:
- java.sql.SQLException- in case of inability to set size.
 
 - 
getMinPoolSizeint getMinPoolSize() Gets the minimum number of connections that the connection pool will maintain.- Returns:
- The minimum number of connections.
 
 - 
setMinPoolSizevoid setMinPoolSize(int minPoolSize) throws java.sql.SQLExceptionSets the minimum number of connections. If the number of available connections PLUS the number of connections in use IS LESS THAN the minimum then the connection is returned to the pool. Otherwise, the connection is closed.The range of valid values is 0 to Integer.MAX_VALUE. It is illegal to set this to a value greater than the maximum pool size. The default is 1 connection.- Parameters:
- minPoolSize- The minimum number of connections.
- Throws:
- java.sql.SQLException- in case of inability to set min pool size.
 
 - 
getMinIdleint getMinIdle() Gets the minimum number of idle connections that the connection pool will maintain.- Returns:
- The minimum number of idle connections.
 
 - 
setMinIdlevoid setMinIdle(int minIdle) throws java.sql.SQLExceptionSets the minimum number of idle connections. If the number of available connections IS LESS THAN the minimum then new connections are created and made available in pool.The range of valid values is 0 to Integer.MAX_VALUE. It is illegal to set this to a value greater than the maximum pool size. The default is 0.- Parameters:
- minIdle- The minimum number of idle connections.
- Throws:
- java.sql.SQLException- in case of inability to set min idle.
 
 - 
getMaxPoolSizeint getMaxPoolSize() Gets the maximum number of connections that the connection pool will maintain.- Returns:
- The maximum number of connections.
 
 - 
setMaxPoolSizevoid setMaxPoolSize(int maxPoolSize) throws java.sql.SQLExceptionSets the maximum number of connections. The maximum number of connections includes the number of connections that are in use as well as the number of available connections.The range of valid values is 1 to Integer.MAX_VALUE. Default value is Integer.MAX_VALUE.- Parameters:
- maxPoolSize- The maximum number of connections.
- Throws:
- java.sql.SQLException- in case of inability to set max pool size.
 
 - 
getInactiveConnectionTimeoutint getInactiveConnectionTimeout() Gets the inactive connection timeout.- Returns:
- The inactivity timeout.
 
 - 
setInactiveConnectionTimeoutvoid setInactiveConnectionTimeout(int inactivityTimeout) throws java.sql.SQLExceptionSets the inactive connection timeout. This timeout determines how long an available connection remains in the connection pool before it is removed from the pool.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 0.Setting the value to 0 disables inactive connection timeout processing. This property's behaviour is affected by the system property oracle.ucp.timersAffectAllConnections. For more details go to -SYSTEM_PROPERTY_TIMERS_AFFECT_ALL_CONNECTIONS.- Parameters:
- inactivityTimeout- The inactive connection timeout in seconds.
- Throws:
- java.sql.SQLException- in case of inability to set timeout.
 
 - 
getAbandonedConnectionTimeoutint getAbandonedConnectionTimeout() Gets the abandoned connection timeout value.- Returns:
- The abandoned connection timeout.
 
 - 
setAbandonedConnectionTimeoutvoid setAbandonedConnectionTimeout(int abandonedConnectionTimeout) throws java.sql.SQLExceptionSets the abandoned connection timeout. This timeout determines how long a borrowed connection can remain unused before it is considered as abandoned and reclaimed by the connection pool.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 0.Setting the value to 0 disables abandoned connection timeout. - Parameters:
- abandonedConnectionTimeout- The value of how long a connection has not been used before it is abandoned (in seconds).
- Throws:
- java.sql.SQLException- in case of inability to set timeout.
 
 - 
getConnectionWaitTimeout@Deprecated int getConnectionWaitTimeout() Deprecated.Gets the maximum time (in seconds) that any connection borrow request can wait before it returns to the application. This method is deprecated. Use getConnectionWaitDuration()instead.- Returns:
- The connection wait timeout.
- See Also:
- setConnectionWaitTimeout(int)
 
 - 
getConnectionWaitDurationjava.time.Duration getConnectionWaitDuration() Gets the maximum time (in seconds) that any connection borrow request can wait before it returns to the application. - Returns:
- The connection wait duration.
- See Also:
- setConnectionWaitDuration(java.time.Duration)
 
 - 
setConnectionWaitTimeout@Deprecated void setConnectionWaitTimeout(int waitTimeout) throws java.sql.SQLExceptionDeprecated.Configures how much time a connection request call may wait before it either successfully returns a connection or throws an exception. The wait duration starts from the point when a connection borrow request is submitted to the pool. During this time, UCP may either return a connection that's currently available in the pool (ideal scenario) or create a new connection if the pool hasn't reached its maximum size. Otherwise, UCP waits for a connection to be returned to the pool. By default, the connection wait timeout is set to 3 seconds. Setting the timeout to 0 makes UCP throw an exception immediately if there is no connection available and no room to grow the pool. Note that it still allows UCP to create a new connection if the maximum size hasn't been reached, and that may take some time. This method is deprecated. Use setConnectionWaitDuration(java.time.Duration)instead.- Parameters:
- waitTimeout- The amount of time in seconds for a connection request to wait.
- Throws:
- java.sql.SQLException- in case it was not possible to set timeout.
 
 - 
setConnectionWaitDurationvoid setConnectionWaitDuration(java.time.Duration waitDuration) throws java.sql.SQLExceptionConfigures how much time a connection request call may wait before it either successfully returns a connection or throws an exception. The wait duration starts from the point when a connection borrow request is submitted to the pool. During this time, UCP may either return a connection that's currently available in the pool (ideal scenario) or create a new connection if the pool hasn't reached its maximum size. Otherwise, UCP waits for a connection to be returned to the pool. By default, the connection wait timeout is set to 3 seconds. Setting the connection wait timeout to Duration.ZEROmakes UCP throw an exception immediately if there is no connection available and no room to grow the pool. Note that it still allows UCP to create a new connection if the maximum size hasn't been reached, and that may take some time.- Parameters:
- waitDuration- The duration for a connection request to wait.
- Throws:
- java.sql.SQLException- in case it was not possible to set timeout.
 
 - 
getTimeToLiveConnectionTimeoutint getTimeToLiveConnectionTimeout() Gets the maximum time (in seconds) a connection may remain in-use. When this timeout expires, the used connection is unconditionally returned to the connection pool. A value of 0 means that the feature is not enabled.- Returns:
- The maximum time (in seconds) a used connection may be active.
 
 - 
setTimeToLiveConnectionTimeoutvoid setTimeToLiveConnectionTimeout(int timeToLiveConnectionTimeout) throws java.sql.SQLExceptionSets the maximum time (in seconds) a connection may remain in-use.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 0.Setting the value to 0 disables time-to-live connection timeout processing. - Parameters:
- timeToLiveConnectionTimeout- The maximum time (in seconds) a used connection may be active.
- Throws:
- java.sql.SQLException- in case of inability to set timeout.
 
 - 
setTimeoutCheckIntervalvoid setTimeoutCheckInterval(int timeInterval) throws java.sql.SQLExceptionSets the timeoutCheckInterval (in seconds). This interval specifies how often the timeout properties such as InactiveConnectionTimeout, AbandonedConnectionTimeout, and TimeToLiveConnectionTimeout are enforced.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 30.Setting the value to 0 disables all connection timeout processing. - Parameters:
- timeInterval- The timeInterval (in seconds) between checks to enforce the timeout properties.
- Throws:
- java.sql.SQLException- in case of inability to set interval.
 
 - 
getTimeoutCheckIntervalint getTimeoutCheckInterval() Gets the timeout check interval (in seconds).- Returns:
- timeInterval The timeInterval(in seconds) between checks to enforce the timeout properties.
 
 - 
setFastConnectionFailoverEnabledvoid setFastConnectionFailoverEnabled(boolean failoverEnabled) throws java.sql.SQLExceptionEnables Fast Connection Failover (FCF) for the connection pool accessed using this pool-enabled data source. By default, FCF is disabled.- Parameters:
- failoverEnabled-- trueif Fast Connection Failover is enabled;- falseif not.
- Throws:
- java.sql.SQLException- in case of inability to set flag.
 
 - 
getFastConnectionFailoverEnabledboolean getFastConnectionFailoverEnabled() Checks if Fast Connection Failover is enabled.- Returns:
- trueif Fast Connection Failover is enabled;- falseif not.
 
 - 
getConnectionFactoryClassNamejava.lang.String getConnectionFactoryClassName() Gets the Connection Factory class name.- Returns:
- Name of the connection factory class specified.
 
 - 
setConnectionFactoryClassNamevoid setConnectionFactoryClassName(java.lang.String factoryClassName) throws java.sql.SQLExceptionSets the Connection Factory class name. This is the connection factory used by the connection pool to create physical connections. Must be set forPoolDataSourceto operate.- Parameters:
- factoryClassName- Connection factory class name for obtaining physical connections.
- Throws:
- java.sql.SQLException- in case of inability to set factory class name.
 
 - 
setMaxStatementsvoid setMaxStatements(int maxStatements) throws java.sql.SQLExceptionSets the maximum number of statements that may be pooled or cached on a connection. This is used to enable the statement pooling.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 0.- Parameters:
- maxStatements- maximum number of statements to be pooled.
- Throws:
- java.sql.SQLException- Exception occurred during the process of setting maximum statements that may be pooled on a connection.
 
 - 
getMaxStatementsint getMaxStatements() Gets the maximum number of statements that may be pooled or cached on a Connection.- Returns:
- m_maxStatements maximum number of statements that may be pooled or cached on a Connection.
 
 - 
setMaxIdleTimevoid setMaxIdleTime(int idleTime) throws java.sql.SQLExceptionSets the maximum idle time for available connections in the pool. This has the same effect as setting the inactive connection timeout.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 0.- Parameters:
- idleTime- Maximum idle time in seconds.
- Throws:
- java.sql.SQLException- in case of inability to set idle time.
 
 - 
getMaxIdleTimeint getMaxIdleTime() Gets the maximum idle time.- Returns:
- The maximum idle time.
 
 - 
setPropertyCyclevoid setPropertyCycle(int propertyCycle) throws java.sql.SQLExceptionSets the property cycle in seconds. This is the time interval between checks to enforce connection pool timeout properties. This has the same effect as settingtimeoutCheckInterval.The range of valid values is 0 to Integer.MAX_VALUE. Defaults to 30.- Parameters:
- propertyCycle- Time interval in seconds to enforce connection pool timeout properties.
- Throws:
- java.sql.SQLException- in case of inability to set property cycle.
 
 - 
getPropertyCycleint getPropertyCycle() Gets the property cycle in seconds.- Returns:
- The PropertyCycle value.
 
 - 
setConnectionPoolNamevoid setConnectionPoolName(java.lang.String connectionpoolName) throws java.sql.SQLExceptionSets the connection pool name. This property allows the user to specify a String value to name a connection pool instance.If not set, the pool name will be automatically generated. - Parameters:
- connectionpoolName- Name of the connection pool.
- Throws:
- java.sql.SQLException- in case of inability to set name.
 
 - 
getConnectionPoolNamejava.lang.String getConnectionPoolName() Gets the connection pool name.- Returns:
- The connection pool name.
 
 - 
setURLvoid setURL(java.lang.String url) throws java.sql.SQLExceptionSets the URL that the data source uses to obtain connections to the database.- Parameters:
- url- URL to be set.
- Throws:
- java.sql.SQLException- in case of inability to set URL.
 
 - 
getURLjava.lang.String getURL() Gets the URL for this data source.- Returns:
- URL for this data source.
 
 - 
setUservoid setUser(java.lang.String userName) throws java.sql.SQLExceptionSets the user name with which connections have to be obtained.- Parameters:
- userName- Username to be set.
- Throws:
- java.sql.SQLException- in case of inability to set user.
 
 - 
getUserjava.lang.String getUser() Gets the user name for this data source.- Returns:
- userName for this data source.
 
 - 
setPasswordvoid setPassword(java.lang.String pd) throws java.sql.SQLExceptionSets the password with which connections have to be obtained.- Parameters:
- pd- Password to be set.
- Throws:
- java.sql.SQLException- in case of inability to set password.
 
 - 
getPassword@Deprecated default java.lang.String getPassword() Deprecated.Gets the Password for this data source.- Returns:
- password for this data source.
 
 - 
setServerNamevoid setServerName(java.lang.String serverName) throws java.sql.SQLExceptionSets the database server name.- Parameters:
- serverName- Database server name to be set.
- Throws:
- java.sql.SQLException- in case of inability to set server name.
 
 - 
getServerNamejava.lang.String getServerName() Gets the database server name.- Returns:
- Database server name.
 
 - 
setPortNumbervoid setPortNumber(int portNumber) throws java.sql.SQLExceptionSets the database port number.- Parameters:
- portNumber- Database port number to be set.
- Throws:
- java.sql.SQLException- in case of inability to set port number.
 
 - 
getPortNumberint getPortNumber() Gets the database port number.- Returns:
- Database port number.
 
 - 
setDatabaseNamevoid setDatabaseName(java.lang.String databaseName) throws java.sql.SQLExceptionSets the database name.- Parameters:
- databaseName- Database name to be set.
- Throws:
- java.sql.SQLException- in case of inability to set db name.
 
 - 
getDatabaseNamejava.lang.String getDatabaseName() Gets the database name.- Returns:
- Database name.
 
 - 
setDataSourceNamevoid setDataSourceName(java.lang.String dataSourceName) throws java.sql.SQLExceptionSets the data source name.- Parameters:
- dataSourceName- data source name to be set.
- Throws:
- java.sql.SQLException- in case of inability to set datasource name.
 
 - 
getDataSourceNamejava.lang.String getDataSourceName() Gets the data source name.- Returns:
- data source name.
 
 - 
setDescriptionvoid setDescription(java.lang.String description) throws java.sql.SQLExceptionSets the data source description.- Parameters:
- description- data source description to be set.
- Throws:
- java.sql.SQLException- in case of inability to set description.
 
 - 
getDescriptionjava.lang.String getDescription() Gets the data source description.- Returns:
- data source description.
 
 - 
setNetworkProtocolvoid setNetworkProtocol(java.lang.String networkProtocol) throws java.sql.SQLExceptionSets the data source network protocol.- Parameters:
- networkProtocol- data source network protocol to be set.
- Throws:
- java.sql.SQLException- in case of inability to set protocol.
 
 - 
getNetworkProtocoljava.lang.String getNetworkProtocol() Gets the data source network protocol.- Returns:
- data source network protocol.
 
 - 
setRoleNamevoid setRoleName(java.lang.String roleName) throws java.sql.SQLExceptionSets the data source role name.- Parameters:
- roleName- data source role name to be set.
- Throws:
- java.sql.SQLException- in case of inability to set role name.
 
 - 
getRoleNamejava.lang.String getRoleName() Gets the data source role name.- Returns:
- data source role name.
 
 - 
setValidateConnectionOnBorrowvoid setValidateConnectionOnBorrow(boolean validateConnectionOnBorrow) throws java.sql.SQLExceptionMakes the pool validate the connection before returning it to the user by calling the JDBC API "isValid". Validating the connection each time it's borrowed from the pool has a performance cost because it typically requires a full roundtrip to the database. You can tune how the Oracle JDBC thin driver validates connections using the "oracle.jdbc.defaultConnectionValidation" property (please refer to the JDBC driver javadoc). You may also configure "secondsToTrustIdleConnection" to avoid validating connections that are often active. Default value is false.- Parameters:
- validateConnectionOnBorrow- Whether or not a connection being borrowed should first be validated.
- Throws:
- java.sql.SQLException- in case of inability to set flag.
- See Also:
- setSecondsToTrustIdleConnection(int)
 
 - 
getValidateConnectionOnBorrowboolean getValidateConnectionOnBorrow() Returns whether or not a connection being borrowed should first be validated.- Returns:
- Whether or not a connection being borrowed should first be validated.
 
 - 
setSQLForValidateConnectionvoid setSQLForValidateConnection(java.lang.String SQLString) throws java.sql.SQLExceptionSets the value of theSQLForValidateConnectionproperty. This is a SQL command used in conjunction with theValidateConnectionOnBorrowproperty. The SQL specified should be applicable to the backend database and the JDBC driver configured. Defaults tonull.- Parameters:
- SQLString- The SQL string used for connection validation.
- Throws:
- java.sql.SQLException- in case of inability to set SQL string.
 
 - 
getSQLForValidateConnectionjava.lang.String getSQLForValidateConnection() Gets the value of theSQLForValidateConnectionproperty.- Returns:
- The SQLForValidateConnection property value.
 
 - 
getConnectionHarvestTriggerCountint getConnectionHarvestTriggerCount() Gets the number of available connections below which the connection pool's connection harvesting will occur. For example, if the value is set to 10, then connection harvesting will occur when the number of available connections drops to 10.- Returns:
- The number of available connections below which the connection pool's connection harvesting will occur.
 
 - 
setConnectionHarvestTriggerCountvoid setConnectionHarvestTriggerCount(int connectionHarvestTriggerCount) throws java.sql.SQLExceptionSets the number of available connections below which the connection pool's connection harvesting will occur.The range of valid values is 0 to maxPoolSize. Defaults toInteger.MAX_VALUE.Setting the value to Integer.MAX_VALUEdisables connection harvesting.- Parameters:
- connectionHarvestTriggerCount- The number of available connections below which the connection pool's connection harvesting will occur.
- Throws:
- java.sql.SQLException- in case of inability to set that count.
 
 - 
getConnectionHarvestMaxCountint getConnectionHarvestMaxCount() Gets the maximum number of connections that may be harvested when the connection harvesting occurs. Note that it is possible that the number of connections that are harvested may be anywhere from 0 to theconnectionHarvestMaxCount.- Returns:
- The maximum number of connections that may be harvested when the connection harvesting occurs.
 
 - 
setConnectionHarvestMaxCountvoid setConnectionHarvestMaxCount(int connectionHarvestMaxCount) throws java.sql.SQLExceptionSets the maximum number of connections that may be harvested when the connection harvesting occurs.The range of valid values is 1 to maxPoolSize. Defaults to 1.- Parameters:
- connectionHarvestMaxCount- the maximum number of connections that may be harvested when the connection harvesting occurs.
- Throws:
- java.sql.SQLException- in case of inability to set that count.
 
 - 
getAvailableConnectionsCountint getAvailableConnectionsCount() throws java.sql.SQLExceptionGets the number of available connections in the pool.- Returns:
- AvailableConnectionsCount
- Throws:
- java.sql.SQLException- in case of inability to set that count.
 
 - 
getBorrowedConnectionsCountint getBorrowedConnectionsCount() throws java.sql.SQLExceptionGets the number of borrowed connections from the pool.- Returns:
- BorrowedConnectionsCount
- Throws:
- java.sql.SQLException- in case of inability to set that count.
 
 - 
getONSConfigurationjava.lang.String getONSConfiguration() throws java.sql.SQLExceptionReturns the ONS configuration string that is used for remote ONS subscription in the form specified insetONSConfiguration(String). This is used by Fast Connection Failover and Runtime Connection Load Balancing.- Returns:
- The ONS configuration string used for remote ONS subscription.
- Throws:
- java.sql.SQLException- in case of inability to set that configuration.
 
 - 
setONSConfigurationvoid setONSConfiguration(java.lang.String onsConfigStr) throws java.sql.SQLExceptionSets the configuration string used for remote ONS subscription. The parameter string closely resembles the content of the ONS configuration file (ons.config). The string contains a list ofname=valuepairs separated by a newline character (\n). The name can be one ofnodes,walletfile, orwalletpassword.The parameter string should at least specify the ONS configuration nodesattribute as a list ofhost:portpairs separated by a comma. SSL would be used when thewalletfileattribute is specified as an Oracle wallet file.An example ONS configuration string: "nodes=host1:4200,host2:4200\nwalletfile=wfile\nwalletpassword=wpwd"This is used primarily by Fast Connection Failover and Runtime Load Balancing.- Parameters:
- onsConfigStr- The configuration string for remote ONS subscription.
- Throws:
- java.sql.SQLException- in case of inability to set that configuration.
 
 - 
getConnectionjava.sql.Connection getConnection(java.util.Properties labels) throws java.sql.SQLExceptionAttempts to obtain a database connection with the requested connection labels.- Parameters:
- labels- The requested connection labels.
- Returns:
- A Connection to the database.
- Throws:
- java.sql.SQLException- if a database-access error occurs.
 
 - 
getConnectionjava.sql.Connection getConnection(java.lang.String username, java.lang.String password, java.util.Properties labels) throws java.sql.SQLExceptionAttempts to obtain a database connection with the requested connection labels.- Parameters:
- username- The database user on whose behalf the connection is being made.
- password- The user's password.
- labels- The requested connection labels.
- Returns:
- A Connection to the database.
- Throws:
- java.sql.SQLException- if a database-access error occurs.
 
 - 
registerConnectionLabelingCallbackvoid registerConnectionLabelingCallback(ConnectionLabelingCallback cbk) throws java.sql.SQLException Registers a connection labeling callback with the underlying connection pool.- Parameters:
- cbk- The- ConnectionLabelingCallbackobject to be registered.
- Throws:
- java.sql.SQLException- If there is a callback already registered with the pool.
 
 - 
removeConnectionLabelingCallbackvoid removeConnectionLabelingCallback() throws java.sql.SQLExceptionRemoves theConnectionLabelingCallbackobject registered with the underlying connection pool, if any.- Throws:
- java.sql.SQLException- If callback removal fails.
 
 - 
registerConnectionAffinityCallbackvoid registerConnectionAffinityCallback(ConnectionAffinityCallback cbk) throws java.sql.SQLException Registers a connection affinity callback on the connection pool.- Parameters:
- cbk- Affinity Callback object that must be registered.
- Throws:
- java.sql.SQLException- If callback registration fails.
 
 - 
removeConnectionAffinityCallbackvoid removeConnectionAffinityCallback() throws java.sql.SQLExceptionRemoves theConnectionAffinityCallbackobject registered on the connection pool.- Throws:
- java.sql.SQLException- If callback removal fails.
 
 - 
getConnectionPropertiesjava.util.Properties getConnectionProperties() Gets the connection properties that are set on this data source.- Returns:
- Connection properties.
 
 - 
getConnectionPropertyjava.lang.String getConnectionProperty(java.lang.String propertyName) Gets the specified connection property that are set on this data source.- Parameters:
- propertyName- The name of the specified property.
- Returns:
- The value of the inquired connection property. Null if the property is not set.
 
 - 
setConnectionPropertyvoid setConnectionProperty(java.lang.String name, java.lang.String value) throws java.sql.SQLExceptionSets a connection property on the connection factory. This is used only for DataSource connection factories that also support connection properties; for example, theoracle.jdbc.pool.OracleDataSourcein the Oracle JDBC driver.- Parameters:
- name- The name of the connection property to be set on the connection factory class.
- value- The value of the connection property to be set on the connection factory class.
- Throws:
- java.sql.SQLException- If any exception occurred while setting the connection property.
- See Also:
- setConnectionFactoryProperties(java.util.Properties)
 
 - 
setConnectionPropertiesvoid setConnectionProperties(java.util.Properties connectionProperties) throws java.sql.SQLExceptionSets the connection properties on the connection factory. This is used only for DataSource connection factories that also support connection properties; for example, theoracle.jdbc.pool.OracleDataSourcein the Oracle JDBC driver.- Parameters:
- connectionProperties- Connection properties to be set on the connection factory class.
- Throws:
- java.sql.SQLException- If any exception occurred while setting the connection properties.
- See Also:
- setConnectionFactoryProperties(java.util.Properties)
 
 - 
getConnectionFactoryPropertiesjava.util.Properties getConnectionFactoryProperties() Gets the connection factory properties that are set on this data source.- Returns:
- Connection factory properties.
 
 - 
getConnectionFactoryPropertyjava.lang.String getConnectionFactoryProperty(java.lang.String propertyName) Gets the specified connection factory property that are set on this data source.- Parameters:
- propertyName- The name of the specified property.
- Returns:
- The value of the inquired connection factory property. Null if the property is not set.
 
 - 
setConnectionFactoryPropertyvoid setConnectionFactoryProperty(java.lang.String name, java.lang.String value) throws java.sql.SQLExceptionSets a connection factory property on the connection factory.For connection factories that implement java.sql.Driver, the connection factory property specified here will be assumed as a connection property.For DataSource connection factories, the property specified here will be assumed as a DataSource property. - Parameters:
- name- The name of the connection factory property to be set on the connection factory class.
- value- The value of the connection factory property to be set on the connection factory class.
- Throws:
- java.sql.SQLException- If any exception occurred while setting the connection factory property.
- java.lang.IllegalArgumentException- If the property name or value is invalid.
 
 - 
setConnectionFactoryPropertiesvoid setConnectionFactoryProperties(java.util.Properties factoryProperties) throws java.sql.SQLExceptionSets the connection factory properties on the connection factory.For connection factories that implement java.sql.Driver, the connection factory properties specified here will be assumed as the connection properties.For DataSource connection factories, the properties specified here will be assumed as the DataSource properties. - Parameters:
- factoryProperties- Connection factory properties to be set on the connection factory class.
- Throws:
- java.sql.SQLException- If any exception occurred while setting the connection factory properties.
- java.lang.IllegalArgumentException- If factoryProperties is empty.
 
 - 
getMaxConnectionReuseTimelong getMaxConnectionReuseTime() Gets the maximum connection reuse time property value. See property description insetMaxConnectionReuseTime().- Returns:
- Maximum connection reuse time (in seconds).
 
 - 
setMaxConnectionReuseTimevoid setMaxConnectionReuseTime(long maxConnectionReuseTime) throws java.sql.SQLExceptionSets the maximum connection reuse time property. This property specifies the maximum time any connection can potentially be reused after which the pool removes and closes a connection. The value is specified in seconds and must be greater than 0. For example, if the specified value is 3600 seconds, then when a connection is in existence for more than 3600 seconds, the connection is closed and removed from the pool. Connections are closed gracefully after they are returned to the pool and the specified property value has been exceeded. Default is 0, which means this feature is not enabled.This property's behaviour is affected by the system property oracle.ucp.timersAffectAllConnections. For more details go to -SYSTEM_PROPERTY_TIMERS_AFFECT_ALL_CONNECTIONS.- Parameters:
- maxConnectionReuseTime- Maximum connection reuse time (in seconds).
- Throws:
- java.sql.SQLException- in case of inability to set reuse time.
 
 - 
getMaxConnectionReuseCountint getMaxConnectionReuseCount() Gets the maximum connection reuse count property value. See property description insetMaxConnectionReuseCount().- Returns:
- Maximum connection reuse count.
 
 - 
setMaxConnectionReuseCountvoid setMaxConnectionReuseCount(int maxConnectionReuseCount) throws java.sql.SQLExceptionSets the maximum connection reuse count property. This property specifies the maximum number of times any connection can be reused after which the pool removes and closes a connection. The value must be greater than 0 for this feature to be enabled. For example, if the specified value is 100, then when a connection is reused or borrowed 100 times from the pool, it is closed and removed from the pool. Connections are closed gracefully after they are returned to the pool and the property value has been exceeded. Default is 0, which means this feature is not enabled.- Parameters:
- maxConnectionReuseCount- Maximum connection reuse count.
- Throws:
- java.sql.SQLException- in case of inability to set reuse time.
 
 - 
getStatisticsJDBCConnectionPoolStatistics getStatistics() Gets the statistics of the connection pool.- Returns:
- The statistics of the connection pool.
 
 - 
registerConnectionInitializationCallbackvoid registerConnectionInitializationCallback(ConnectionInitializationCallback cbk) throws java.sql.SQLException Registers a connection initialization callback.- Parameters:
- cbk- The- ConnectionInitializationCallbackobject to be registered.
- Throws:
- java.sql.SQLException- If there is a callback already registered with the pool.
 
 - 
unregisterConnectionInitializationCallbackvoid unregisterConnectionInitializationCallback() throws java.sql.SQLExceptionUnregisters the connection initialization callback on this pool.- Throws:
- java.sql.SQLException- If callback removal fails.
 
 - 
getConnectionInitializationCallbackConnectionInitializationCallback getConnectionInitializationCallback() Obtains the registered connection initialization callback, if any.- Returns:
- The registered ConnectionInitializationCallback, or null if there is no callback registered.
 
 - 
registerConnectionCreationConsumerdefault void registerConnectionCreationConsumer(java.util.function.Consumer<oracle.ucp.ConnectionCreationInformation> consumer) Registers a connection creation Consumer.- Parameters:
- consumer- The- Consumerobject to be registered.
 
 - 
unregisterConnectionCreationConsumerdefault void unregisterConnectionCreationConsumer() Unregisters the connection creation Consumer on this pool.
 - 
getConnectionCreationConsumerdefault java.util.function.Consumer<oracle.ucp.ConnectionCreationInformation> getConnectionCreationConsumer() Obtains the registered connection creation Consumer, if any.- Returns:
- The registered Consumer, or null if there is no Consumer registered.
 
 - 
getConnectionLabelingHighCostint getConnectionLabelingHighCost() Obtains the cost value which identifies a connection as "high-cost" for connection labeling.- Returns:
- The cost value that identifies a connection as "high-cost" for connection labeling.
- See Also:
- setConnectionLabelingHighCost(int)
 
 - 
setConnectionLabelingHighCostvoid setConnectionLabelingHighCost(int highCost) throws java.sql.SQLExceptionSets the cost value which identifies a connection as "high-cost" for connection labeling. Connection labeling uses thecost(Properties, Properties)method in ConnectionLabelingCallback to find a connection in the pool for a request. When this property is set, connections with a cost value equal to or greater than the property value are considered "high-cost" connections. The default value is Integer.MAX_VALUE.- Parameters:
- highCost- The cost value that identifies a connection as "high-cost" for connection labeling.
- Throws:
- java.sql.SQLException- If an exception occurs while setting the cost.
 
 - 
getHighCostConnectionReuseThresholdint getHighCostConnectionReuseThreshold() Obtains the high-cost connection reuse threshold property value for connection labeling.- Returns:
- The high-cost connection reuse threshold property value currently set.
- See Also:
- setConnectionLabelingHighCost(int),- setHighCostConnectionReuseThreshold(int)
 
 - 
setHighCostConnectionReuseThresholdvoid setHighCostConnectionReuseThreshold(int threshold) throws java.sql.SQLExceptionSets the high-cost connection reuse threshold for connection labeling. This property works together with the ConnectionLabelingHighCost property to determine when high-cost connections are reused for connection labeling. This property specifies a threshold of the number of total connections in the pool. If Connection Labeling finds all available connections are high-cost connections (i.e., the lowest cost value exceeds the ConnectionLabelingHighCost value), it checks this threshold to determine whether to reuse those connections. Only when this threshold is reached, Connection Labeling will try to reuse the high-cost connections in the pool to serve a labeled connection request. Otherwise, Connection Labeling picks a low-cost connection, a no-label connection available in the pool, or creates a brand-new physical connection to serve a labeled request. For example, if the property value is set to 10, Connection Labeling reuses high-cost connections when there are no low-cost connections available and the total connections reach 10. Note that any labeled connection with cost Integer.MAX_VALUE will not be reused. This is consistent with connection labeling behavior when this property and ConnectionLabelingHighCost are not set. A Connection Labeling callback must be registered at the same time for this property to take effect. The default value is 0, which is treated the same way as MinPoolSize.- Parameters:
- threshold- The high-cost connection reuse threshold to set.
- Throws:
- java.sql.SQLException- If any exception occurs while setting the threshold.
 
 - 
createConnectionBuilderUCPConnectionBuilder createConnectionBuilder() Creates a new UCPConnectionBuilder instance.- Specified by:
- createConnectionBuilderin interface- javax.sql.DataSource
- Returns:
- The OracleConnectionBuilder instance that was created
 
 - 
createShardingKeyBuilderdefault oracle.jdbc.OracleShardingKeyBuilder createShardingKeyBuilder() Creates a new OracleShardingKeyBuilder instance- Specified by:
- createShardingKeyBuilderin interface- javax.sql.CommonDataSource
- Returns:
- The OracleShardingKeyBuilder instance that was created
 
 - 
getConnectionRepurposeThresholdint getConnectionRepurposeThreshold() Gets the connection repurpose threshold for the pool. This property is used in cases when the connection pool is shared by multiple datasources connecting to the same database but using different services.Only when this threshold is reached the pool will try to repurpose connections between different services before trying to create new connections. This property is applicable only for multi-tenant databases.- Returns:
- connection repurpose threshold property value currently set.
 
 - 
setConnectionRepurposeThresholdvoid setConnectionRepurposeThreshold(int threshold) throws java.sql.SQLExceptionSets the connection repurpose threshold for the pool. This property is applicable only for multi-tenant databases.- Parameters:
- threshold- connection repurpose threshold to set.
- Throws:
- java.sql.SQLException- If any exception occurs while setting the threshold.
- See Also:
- getConnectionRepurposeThreshold()
 
 - 
getPdbRolesjava.util.Properties getPdbRoles() Gets the PDB roles specified for this datasource- Returns:
- roles key values pairs that correspond to the role names and password that are set for this datasource
 
 - 
getServiceNamejava.lang.String getServiceName() Gets the service name set on this data source- Returns:
- service name on this data source
 
 - 
getSecondsToTrustIdleConnectionint getSecondsToTrustIdleConnection() Gets the seconds To Trust Idle Connection value.- Returns:
- The seconds To Trust Idle Connection.
 
 - 
setSecondsToTrustIdleConnectionvoid setSecondsToTrustIdleConnection(int secondsToTrustIdleConnection) throws java.sql.SQLExceptionSets the time in seconds to trust an idle connection to skip a validation test. It works in conjunction withsetValidateConnectionOnBorrow(boolean). When set to any positive value, a connection validation during the checkout is skipped if the connection was successfully used and returned to the pool within the time specified for secondsToTrustIdleConnection. Default value is set to 0 seconds which means that the feature is disabled.With this mode enabled, UCP will do a SOCKET validation on every connection borrow and default driver validation type (can be changed with the "oracle.jdbc.defaultConnectionValidation" system property) after designated seconds to trust idle connection has passed * @param secondsToTrustIdleConnection The value of how long a connection can be trusted to skip connectionValidationOnBorrow- Throws:
- java.sql.SQLException- in case of inability to set these seconds.
 
 - 
reconfigureDataSourcevoid reconfigureDataSource(java.util.Properties configuration) throws java.sql.SQLExceptionReconfigures the data source. This API can be only used to modify existing data source properties. To add a new data source to a running pool instance, use PoolDataSourceFactory's getPoolDataSource(Properties configuration) API instead. Only the following data source properties can be modified using this API:user,password,description,serviceName,pdbRoles.- Parameters:
- configuration- the configuration input
- Throws:
- java.sql.SQLException- If an error occurs while configuring the data source.
 
 - 
getMaxConnectionsPerServiceint getMaxConnectionsPerService() Gets the maximum number of connections that can be obtained to a particular service, in a shared pool.- Returns:
- The maximum number of connections that can be obtained to a particular service.
 
 - 
getQueryTimeoutint getQueryTimeout() Gets the number of seconds the driver will wait for a Statement object to execute to the given number of seconds.- Returns:
- The query timeout in seconds
 
 - 
setQueryTimeoutvoid setQueryTimeout(int queryTimeout) throws java.sql.SQLExceptionSets the number of seconds the driver will wait for a Statement object to execute to the given number of seconds.- Parameters:
- queryTimeout- in seconds
- Throws:
- java.sql.SQLException- in case of inability to set that timeout.
 
 - 
getMaxConnectionsPerShardint getMaxConnectionsPerShard() Gets the currently configured max connections that can be created per shard from this connection pool.- Returns:
- The configured max number of connections that can be created per shard.
 
 - 
setMaxConnectionsPerShardvoid setMaxConnectionsPerShard(int maxConnectionsPerShard) throws java.sql.SQLExceptionSets the max number of connections that can be created per shard from this connection pool. (Note: This property is applicable to Sharded databases only. It should not be used when the Sharded database is configured with Oracle Golden Gate)- Parameters:
- maxConnectionsPerShard- The max number of connections that can be created per shard
- Throws:
- java.sql.SQLException- if there is an any exception while setting this parameter
 
 - 
setShardingModevoid setShardingMode(boolean shardingMode) throws java.sql.SQLExceptionThis API changes the mode of UCP when UCP is using a Sharded Database. By default UCP requires the caller to provide a sharding key for every connection request. When switching off the sharding mode, UCP behaves like a regular connection pool and all the sharding features are disabled so that a caller can request a connection without providing any sharding key.- Parameters:
- shardingMode- Mode of UCP when using a Sharded Database.
- Throws:
- java.sql.SQLException- in case of inability to set sharding mode.
 
 - 
getShardingModeboolean getShardingMode() Returns the mode of UCP when UCP is using a Sharded Database. By default sharding mode is ON which means UCP requires the caller to provide a sharding key for every connection request.- Returns:
- Mode of UCP when using a Sharded Database.
 
 - 
setConnectionValidationTimeoutvoid setConnectionValidationTimeout(int connectionValidationTimeout) throws java.sql.SQLExceptionThis property changes the connection validation timeout which is specified in seconds. Default is 15 seconds. This is the maximum time for connection validation operation. If not completed during this timeout, the connection is treated as invalid.- Parameters:
- connectionValidationTimeout- timeout to validate connection
- Throws:
- java.sql.SQLException- if tiomeout is negative
 
 - 
getConnectionValidationTimeoutint getConnectionValidationTimeout() Connection validation timeout getter- Returns:
- the current connection validation timaout value in seconds
 
 - 
setSSLContextvoid setSSLContext(javax.net.ssl.SSLContext sslContext) Specifies aSSLContextto use as a factory for SSLEngine objects that carry out the TLS protocol.The SSLContext must be initialized before setting it on PoolDataSource. The certificates specified by that initialization will be used in place of any connection properties that would otherwise have specified certificates, such as oracle.jdbc.OracleConnection#CONNECTION_PROPERTY_KEYSTORE key store and oracle.jdbc.OracleConnection#CONNECTION_PROPERTY_TRUSTSTORE trust store property values. - Parameters:
- sslContext- SSLContext instance to be used as an SSLEngine factory.
 
 - 
setHostnameResolvervoid setHostnameResolver(PoolDataSource.HostnameResolver hostnameResolver) Specifies aPoolDataSource.HostnameResolverto use by the pool- Parameters:
- hostnameResolver- HostnameResolver instance to be used as a custom DNS name resolver.
 
 - 
isReadOnlyInstanceAllowedboolean isReadOnlyInstanceAllowed() Returns true if the connection borrow is allowed to a read-only instance, false otherwise. This property is applicable to sharded database only. A shard instance can be in read-only mode for a chunk if chunk move/split operation is in progress.- Returns:
- true if the connection borrow is allowed to a read-only instance, false otherwise.
 
 - 
setReadOnlyInstanceAllowedvoid setReadOnlyInstanceAllowed(boolean readOnlyInstanceAllowed) throws java.sql.SQLExceptionSets the read-only instance allowed value on the datasource. This property is applicable to sharded database only. When the property value is set to true, UCP allows connection borrow to read-only instances as well otherwise not. A shard instance goes into read-only mode for a chunk if the chunk move/split operation is in progress on that instance. The default value is false which means by default connection borrow is not allowed to a read-only instance.- Parameters:
- readOnlyInstanceAllowed- whether to allow connection borrow to a read-only instance or not
- Throws:
- java.sql.SQLException- if unable to set property value
 
 - 
setTokenSuppliervoid setTokenSupplier(java.util.function.Supplier<? extends oracle.jdbc.AccessToken> tokenSupplier) throws java.sql.SQLExceptionSets a supplier function that generates an access token when creating a connection with this DataSource. The supplier function is invoked each time thisDataSourcecreates a connection. Instances ofAccessTokenthat are output by the supplier must represent a token type that is supported by Oracle Database for client authentication. The supplier must be thread safe.It is invalid to configure this DataSourcewith both a token supplier and with a user name or password. If invocations ofsetUser(String),setPassword(String),setConnectionProperties(java.util.Properties), orsetConnectionProperty(String, String)have configured thisDataSourcewith a user name or password, and an invocation of this method has also configured a token supplier, then aSQLExceptionindicating an invalid configuration is thrown when creating a connection with this datasource.Note that AccessToken.createJsonWebTokenCache(Supplier)can be called to create a thread safeSupplierthat caches tokens from a user definedSupplier.- Parameters:
- tokenSupplier- Token supplying function. Not- null.
- Throws:
- java.lang.NullPointerException- If the- tokenSupplieris null.
- java.sql.SQLException- if unable to set property value
 
 - 
isCreateConnectionInBorrowThreadboolean isCreateConnectionInBorrowThread() Returns the connection creation mode: either "true" if connections are created using the borrowing thread, or "false" if connections are created in the background (the default).- Returns:
- true, if creating connections in a borrow thread, false otherwise.
- See Also:
- setCreateConnectionInBorrowThread(boolean)
 
 - 
setCreateConnectionInBorrowThreadvoid setCreateConnectionInBorrowThread(boolean createConnectionInBorrowThread) throws java.sql.SQLExceptionSet this flag to true to make UCP use the borrowing thread to create new connections. By default, connections are created in the background. The only reason why you may want to set this to "true" is to make a connection request fail-fast if the driver throws an exception while connecting; otherwise, the background task will keep trying until the connection wait timeout expires. If this property is set to false, a pool waits no longer than a designated connection wait duration no matter how long it takes to create a new connection to grow a pool, if no connection is available at this moment. If this property is set to true, then in this backward compatibility mode a pool waits for a connection to be synchronously created in a borrow thread, and the waiting time can take longer than connectionWaitDuration. For connectionWaitDuration please refer to setConnectionWaitDuration(java.time.Duration).- Parameters:
- createConnectionInBorrowThread- if true, create connections in a borrow thread.
- Throws:
- java.sql.SQLException- if unable to set property value.
 
 - 
isCommitOnConnectionReturnboolean isCommitOnConnectionReturn() Returns the boolean value for the property that controls the behavior of UCP when a connection is released back to the pool with pending uncommitted changes in an active transaction. By default, UCP will commit the changes (default value is "true"). When setting this property to "false" the changes will be rolled back.- Returns:
- true to commit, false to rollback.
 
 - 
setCommitOnConnectionReturnvoid setCommitOnConnectionReturn(boolean commit) throws java.sql.SQLExceptionSets the boolean value for the property that controls the behavior of UCP when a connection is released back to the pool with pending uncommitted changes in an active transaction. By default, UCP will commit the changes (default value is "true"). When setting this property to "false" the changes will be rolled back.- Parameters:
- commit- 'true' to commit, 'false' to rollback. The default is 'true'.
- Throws:
- java.sql.SQLException
 
 
- 
 
-