|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.jdbc.support.JdbcUtils
public abstract class JdbcUtils
Generic utility methods for working with JDBC. Mainly for internal use within the framework, but also useful for custom JDBC access code.
Constructor Summary | |
---|---|
JdbcUtils()
|
Method Summary | |
---|---|
static void |
closeConnection(Connection con)
Close the given JDBC Connection and ignore any thrown exception. |
static void |
closeResultSet(ResultSet rs)
Close the given JDBC ResultSet and ignore any thrown exception. |
static void |
closeStatement(Statement stmt)
Close the given JDBC Statement and ignore any thrown exception. |
static int |
countParameterPlaceholders(String str,
char placeholder,
char delim)
Count the occurrences of the character placeholder in an SQL string
str . |
static int |
countParameterPlaceholders(String str,
char placeholder,
String delimiters)
Count the occurrences of the character placeholder in an SQL string
str . |
static Object |
extractDatabaseMetaData(DataSource dataSource,
DatabaseMetaDataCallback action)
Extract database meta data via the given DatabaseMetaDataCallback. |
static Object |
extractDatabaseMetaData(DataSource dataSource,
String metaDataMethodName)
Call the specified method on DatabaseMetaData for the given DataSource, and extract the invocation result. |
static Object |
getResultSetValue(ResultSet rs,
int index)
Retrieve a JDBC column value from a ResultSet, using the most appropriate value type. |
static boolean |
isNumeric(int sqlType)
Check that a SQL type is numeric. |
static boolean |
supportsBatchUpdates(Connection con)
Return whether the given JDBC driver supports JDBC 2.0 batch updates. |
static int |
translateType(int sqlType)
Deprecated. This is only used by deprecated constructors in SqlFunction and will be removed alongside those constructors. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public JdbcUtils()
Method Detail |
---|
public static void closeConnection(Connection con)
con
- the JDBC Connection to closepublic static void closeStatement(Statement stmt)
stmt
- the JDBC Statement to closepublic static void closeResultSet(ResultSet rs)
rs
- the JDBC ResultSet to closepublic static Object getResultSetValue(ResultSet rs, int index) throws SQLException
Uses the getObject(index)
method, but includes additional "hacks"
to get around Oracle 10g returning a non-standard object for its TIMESTAMP
datatype and a java.sql.Date
for DATE columns leaving out the
time portion: These columns will explicitly be extracted as standard
java.sql.Timestamp
object.
rs
- is the ResultSet holding the dataindex
- is the column index
SQLException
Blob
,
Clob
,
Timestamp
,
oracle.sql.TIMESTAMP
public static Object extractDatabaseMetaData(DataSource dataSource, DatabaseMetaDataCallback action) throws MetaDataAccessException
This method will open a connection to the database and retrieve the database metadata. Since this method is called before the exception translation feature is configured for a datasource, this method can not rely on the SQLException translation functionality.
Any exceptions will be wrapped in a MetaDataAccessException. This is a checked exception and any calling code should catch and handle this exception. You can just log the error and hope for the best, but there is probably a more serious error that will reappear when you try to access the database again.
dataSource
- the DataSource to extract metadata foraction
- callback that will do the actual work
processMetaData
method
MetaDataAccessException
- if meta data access failedpublic static Object extractDatabaseMetaData(DataSource dataSource, String metaDataMethodName) throws MetaDataAccessException
dataSource
- the DataSource to extract meta data formetaDataMethodName
- the name of the DatabaseMetaData method to call
MetaDataAccessException
- if we couldn't access the DatabaseMetaData
or failed to invoke the specified methodDatabaseMetaData
public static boolean supportsBatchUpdates(Connection con)
Typically invoked right before execution of a given set of statements: to decide whether the set of SQL statements should be executed through the JDBC 2.0 batch mechanism or simply in a traditional one-by-one fashion.
Logs a warning if the "supportsBatchUpdates" methods throws an exception and simply returns false in that case.
con
- the Connection to check
DatabaseMetaData.supportsBatchUpdates()
public static int countParameterPlaceholders(String str, char placeholder, char delim)
placeholder
in an SQL string
str
. The character placeholder
is not counted if it
appears within a literal as determined by the delim
that is passed in.
Delegates to the overloaded method that takes a String with multiple delimiters.
str
- string to search in. Returns 0 if this is null.placeholder
- the character to search for and countdelim
- the delimiter for character literalspublic static int countParameterPlaceholders(String str, char placeholder, String delimiters)
placeholder
in an SQL string
str
. The character placeholder
is not counted if it
appears within a literal as determined by the delimiters
that are passed in.
Examples: If one of the delimiters is the single quote, and the character to count the occurrences of is the question mark, then:
The big ? 'bad wolf?'
gives a count of one.
The big ?? bad wolf
gives a count of two.
The big 'ba''ad?' ? wolf
gives a count of one.
The grammar of the string passed in should obey the rules of the JDBC spec which is close to no rules at all: one placeholder per parameter, and it should be valid SQL for the target database.
str
- string to search in. Returns 0 if this is nullplaceholder
- the character to search for and count.delimiters
- the delimiters for character literals.public static boolean isNumeric(int sqlType)
sqlType
- the SQL type to be checked
public static int translateType(int sqlType)
sqlType
- the type to be translated into a simpler type
SqlFunction.SqlFunction(javax.sql.DataSource, String, int)
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |