public 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 though 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 and Description |
---|---|
default ConnectionBuilder |
createConnectionBuilder()
Create a new
ConnectionBuilder instance |
default ShardingKeyBuilder |
createShardingKeyBuilder()
Create a new
ShardingKeyBuilder 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. |
getLoginTimeout, getLogWriter, getParentLogger, setLoginTimeout, setLogWriter
isWrapperFor, unwrap
Connection 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 attemptdefault ConnectionBuilder createConnectionBuilder() throws SQLException
ConnectionBuilder
instanceSQLFeatureNotSupportedException
SQLException
- if an error occurs creating the builderSQLFeatureNotSupportedException
- if the driver does not support shardingcreateConnectionBuilder
default ShardingKeyBuilder createShardingKeyBuilder() throws SQLException
ShardingKeyBuilder
instanceSQLFeatureNotSupportedException
SQLException
- if an error occurs creating the builderSQLFeatureNotSupportedException
- if the driver does not support this methodShardingKeyBuilder
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, 2016, Oracle and/or its affiliates. All rights reserved.
DRAFT 9-internal+0-2016-01-26-133437.ivan.openjdk9onspinwait