CommonDataSource, Wrapperpublic interface DataSource extends CommonDataSource, Wrapper
A factory for connections to the physical data source that this
DataSource object represents. An alternative to the
DriverManager facility, a DataSource object
is the preferred means of getting a connection. An object that implements
the DataSource interface will typically be
registered with a naming service based on the
Java™ Naming and Directory (JNDI) API.
The DataSource interface is implemented by a driver vendor.
There are three types of implementations:
Connection
object
Connection
object that will automatically participate in connection pooling. This
implementation works with a middle-tier connection pooling manager.
Connection object that may be used for distributed
transactions and almost always participates in connection pooling.
This implementation works with a middle-tier
transaction manager and almost always with a connection
pooling manager.
A DataSource object has properties that can be modified
when necessary. For example, if the data source is moved to a different
server, the property for the server can be changed. The benefit is that
because the data source's properties can be changed, any code accessing
that data source does not need to be changed.
A driver that is accessed via a DataSource object does not
register itself with the DriverManager. Rather, a
DataSource object is retrieved through a lookup operation
and then used to create a Connection object. With a basic
implementation, the connection obtained through a DataSource
object is identical to a connection obtained through the
DriverManager facility.
An implementation of DataSource must include a public no-arg
constructor.
| Modifier and Type | Method | Description |
|---|---|---|
default ConnectionBuilder |
createConnectionBuilder() |
Create a new
ConnectionBuilder instance |
Connection |
getConnection() |
Attempts to establish a connection with the data source that
this
DataSource object represents. |
Connection |
getConnection(String username,
String password) |
Attempts to establish a connection with the data source that
this
DataSource object represents. |
int |
getLoginTimeout() |
Gets the maximum time in seconds that this data source can wait
while attempting to connect to a database.
|
PrintWriter |
getLogWriter() |
Retrieves the log writer for this
DataSource
object. |
void |
setLoginTimeout(int seconds) |
Sets the maximum time in seconds that this data source will wait
while attempting to connect to a database.
|
void |
setLogWriter(PrintWriter out) |
Sets the log writer for this
DataSource
object to the given java.io.PrintWriter object. |
createShardingKeyBuilder, getParentLoggerisWrapperFor, unwrapConnection getConnection() throws SQLException
Attempts to establish a connection with the data source that
this DataSource object represents.
SQLException - if a database access error occursSQLTimeoutException - when the driver has determined that the
timeout value specified by the setLoginTimeout method
has been exceeded and has at least tried to cancel the
current database connection attemptConnection getConnection(String username, String password) throws SQLException
Attempts to establish a connection with the data source that
this DataSource object represents.
username - the database user on whose behalf the connection is
being madepassword - the user's passwordSQLException - if a database access error occursSQLTimeoutException - when the driver has determined that the
timeout value specified by the setLoginTimeout method
has been exceeded and has at least tried to cancel the
current database connection attemptPrintWriter getLogWriter() throws SQLException
Retrieves the log writer for this DataSource
object.
The log writer is a character output stream to which all logging
and tracing messages for this data source will be
printed. This includes messages printed by the methods of this
object, messages printed by methods of other objects manufactured
by this object, and so on. Messages printed to a data source
specific log writer are not printed to the log writer associated
with the java.sql.DriverManager class. When a
DataSource object is
created, the log writer is initially null; in other words, the
default is for logging to be disabled.
getLogWriter in interface CommonDataSourceSQLException - if a database access error occursCommonDataSource.setLogWriter(java.io.PrintWriter)void setLogWriter(PrintWriter out) throws SQLException
Sets the log writer for this DataSource
object to the given java.io.PrintWriter object.
The log writer is a character output stream to which all logging
and tracing messages for this data source will be
printed. This includes messages printed by the methods of this
object, messages printed by methods of other objects manufactured
by this object, and so on. Messages printed to a data source-
specific log writer are not printed to the log writer associated
with the java.sql.DriverManager class. When a
DataSource object is created the log writer is
initially null; in other words, the default is for logging to be
disabled.
setLogWriter in interface CommonDataSourceout - the new log writer; to disable logging, set to nullSQLException - if a database access error occursCommonDataSource.getLogWriter()void setLoginTimeout(int seconds)
throws SQLException
Sets the maximum time in seconds that this data source will wait
while attempting to connect to a database. A value of zero
specifies that the timeout is the default system timeout
if there is one; otherwise, it specifies that there is no timeout.
When a DataSource object is created, the login timeout is
initially zero.
setLoginTimeout in interface CommonDataSourceseconds - the data source login time limitSQLException - if a database access error occurs.CommonDataSource.getLoginTimeout()int getLoginTimeout()
throws SQLException
DataSource object is created, the login timeout is
initially zero.getLoginTimeout in interface CommonDataSourceSQLException - if a database access error occurs.CommonDataSource.setLoginTimeout(int)default ConnectionBuilder createConnectionBuilder() throws SQLException
ConnectionBuilder instanceSQLFeatureNotSupportedExceptionSQLException - if an error occurs creating the builderSQLFeatureNotSupportedException - if the driver does not support shardingConnectionBuilder Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2017, Oracle and/or its affiliates. 500 Oracle Parkway
Redwood Shores, CA 94065 USA. All rights reserved.
DRAFT 9-Debian+0-9b153-2