- All Superinterfaces:
AutoCloseable
Manages a
Connection
instance, providing basic transaction control.
A factory for DatabaseConnection instances.-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
SQLException state indicating that a query did not return a result -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Performs a rollback and disconnects this connection.void
commit()
Performs a commitvoid
Performs a commit and ends the current transactionboolean
Note that this method does not check if the connection is valid, only that it is connected.database()
static DatabaseConnection
databaseConnection
(Database database, User user) Constructs a new DatabaseConnection instance, based on the given Database and Userstatic DatabaseConnection
databaseConnection
(Database database, Connection connection) Constructs a new DatabaseConnection instance, based on the given Connection object.Returns the underlying connection object.void
rollback()
Performs a rollbackvoid
Performs a rollback and ends the current transactionvoid
setConnection
(@Nullable Connection connection) Sets the internal connection to use, note that no validation or transaction checking is performed on the connection and auto-commit is assumed to be disabled.void
setMethodLogger
(@Nullable MethodLogger methodLogger) void
Starts a transaction on this connection, to end the transaction usecommitTransaction()
orrollbackTransaction()
.boolean
user()
boolean
valid()
-
Field Details
-
SQL_STATE_NO_DATA
SQLException state indicating that a query did not return a result- See Also:
-
-
Method Details
-
connected
boolean connected()Note that this method does not check if the connection is valid, only that it is connected.- Returns:
- true if a connection has been established
- See Also:
-
valid
boolean valid()- Returns:
- true if a connection has been established and is valid
- See Also:
-
getConnection
Connection getConnection()Returns the underlying connection object. Usevalid()
to verify that the connection is available and valid.- Returns:
- the underlying connection object
- Throws:
IllegalStateException
- in case this connection has been closed- See Also:
-
setConnection
Sets the internal connection to use, note that no validation or transaction checking is performed on the connection and auto-commit is assumed to be disabled. The connection is simply used 'as is'. Note that setting the connection to null causes all methods requiring it to throw aIllegalStateException
until a non-null connection is set.- Parameters:
connection
- the JDBC connection
-
startTransaction
void startTransaction()Starts a transaction on this connection, to end the transaction usecommitTransaction()
orrollbackTransaction()
.- Throws:
IllegalStateException
- in case a transaction is already open
-
transactionOpen
boolean transactionOpen()- Returns:
- true if a transaction is open
-
commitTransaction
Performs a commit and ends the current transaction- Throws:
SQLException
- in case the commit failedIllegalStateException
- in case a transaction is not open
-
rollbackTransaction
Performs a rollback and ends the current transaction- Throws:
SQLException
- in case the rollback failedIllegalStateException
- in case a transaction is not open
-
commit
Performs a commit- Throws:
SQLException
- thrown if anything goes wrong during the commitIllegalStateException
- in case a transaction is already open
-
rollback
Performs a rollback- Throws:
SQLException
- thrown if anything goes wrong during the rollbackIllegalStateException
- in case a transaction is open
-
close
void close()Performs a rollback and disconnects this connection. The only way to resurrect a closed connection is by usingsetConnection(Connection)
. Calling this method renders this connection unusable, subsequent calls to methods using the underlying connection result in aIllegalStateException
being thrown, that is, until a newConnection
is set viasetConnection(Connection)
.- Specified by:
close
in interfaceAutoCloseable
-
user
User user()- Returns:
- the connection user
-
database
Database database()- Returns:
- the database implementation this connection is based on
-
setMethodLogger
- Parameters:
methodLogger
- the MethodLogger to use, null to disable method logging
-
getMethodLogger
@Nullable MethodLogger getMethodLogger()- Returns:
- the MethodLogger being used, possibly null
-
databaseConnection
Constructs a new DatabaseConnection instance, based on the given Database and User- Parameters:
database
- the databaseuser
- the user to use when establishing a connection- Returns:
- a new DatabaseConnection instance
- Throws:
DatabaseException
- in case there is a problem connecting to the database
-
databaseConnection
Constructs a new DatabaseConnection instance, based on the given Connection object. NB. auto commit is disabled on the Connection that is provided.- Parameters:
database
- the databaseconnection
- the Connection object to base this DatabaseConnection on- Returns:
- a new DatabaseConnection instance
- Throws:
DatabaseException
- in case there is a problem with the connection
-