Package org.springframework.jdbc.support
Class SQLErrorCodeSQLExceptionTranslator
java.lang.Object
org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator
org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator
- All Implemented Interfaces:
- SQLExceptionTranslator
Implementation of 
SQLExceptionTranslator that analyzes vendor-specific error codes.
 More precise than an implementation based on SQL state, but heavily vendor-specific.
 This class applies the following matching rules:
- Try custom translation implemented by any subclass. Note that this class is concrete and is typically used itself, in which case this rule doesn't apply.
- Apply error code matching. Error codes are obtained from the SQLErrorCodesFactory by default. This factory loads a "sql-error-codes.xml" file from the class path, defining error code mappings for database names from database meta-data.
- Fallback to a fallback translator. SQLStateSQLExceptionTranslatoris the default fallback translator, analyzing the exception's SQL state only. On Java 6 which introduces its ownSQLExceptionsubclass hierarchy, we will useSQLExceptionSubclassTranslatorby default, which in turns falls back to Spring's own SQL state translation when not encountering specific subclasses.
The configuration file named "sql-error-codes.xml" is by default read from this package. It can be overridden through a file of the same name in the root of the class path (e.g. in the "/WEB-INF/classes" directory), as long as the Spring JDBC package is loaded from the same ClassLoader.
- Author:
- Rod Johnson, Thomas Risberg, Juergen Hoeller
- See Also:
- 
Field SummaryFields inherited from class org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslatorlogger
- 
Constructor SummaryConstructorsConstructorDescriptionConstructor for use as a JavaBean.Create an SQL error code translator for the given database product name.SQLErrorCodeSQLExceptionTranslator(DataSource dataSource) Create an SQL error code translator for the given DataSource.Create an SQLErrorCode translator given these error codes.
- 
Method SummaryModifier and TypeMethodDescriptionprotected DataAccessExceptioncreateCustomException(String task, String sql, SQLException sqlEx, Class<?> exceptionClass) Create a customDataAccessException, based on a given exception class from aCustomSQLErrorCodesTranslationdefinition.protected DataAccessExceptioncustomTranslate(String task, String sql, SQLException sqlEx) Subclasses can override this method to attempt a custom mapping fromSQLExceptiontoDataAccessException.protected DataAccessExceptiondoTranslate(String task, String sql, SQLException ex) Template method for actually translating the given exception.Return the error codes used by this translator.voidsetDatabaseProductName(String dbName) Set the database product name for this translator.voidsetDataSource(DataSource dataSource) Set the DataSource for this translator.voidSet custom error codes to be used for translation.Methods inherited from class org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslatorbuildMessage, getFallbackTranslator, setFallbackTranslator, translate
- 
Constructor Details- 
SQLErrorCodeSQLExceptionTranslatorpublic SQLErrorCodeSQLExceptionTranslator()Constructor for use as a JavaBean. The SqlErrorCodes or DataSource property must be set.
- 
SQLErrorCodeSQLExceptionTranslatorCreate an SQL error code translator for the given DataSource. Invoking this constructor will cause a Connection to be obtained from the DataSource to get the meta-data.- Parameters:
- dataSource- the DataSource to use to find meta-data and establish which error codes are usable
- See Also:
 
- 
SQLErrorCodeSQLExceptionTranslatorCreate an SQL error code translator for the given database product name. Invoking this constructor will avoid obtaining a Connection from the DataSource to get the meta-data.- Parameters:
- dbName- the database product name that identifies the error codes entry
- See Also:
 
- 
SQLErrorCodeSQLExceptionTranslatorCreate an SQLErrorCode translator given these error codes. Does not require a database meta-data lookup to be performed using a connection.- Parameters:
- sec- error codes
 
 
- 
- 
Method Details- 
setDataSourceSet the DataSource for this translator.Setting this property will cause a Connection to be obtained from the DataSource to get the meta-data. - Parameters:
- dataSource- the DataSource to use to find meta-data and establish which error codes are usable
- See Also:
 
- 
setDatabaseProductNameSet the database product name for this translator.Setting this property will avoid obtaining a Connection from the DataSource to get the meta-data. - Parameters:
- dbName- the database product name that identifies the error codes entry
- See Also:
 
- 
setSqlErrorCodesSet custom error codes to be used for translation.- Parameters:
- sec- custom error codes to use
 
- 
getSqlErrorCodesReturn the error codes used by this translator. Usually determined via a DataSource.- See Also:
 
- 
doTranslate@Nullable protected DataAccessException doTranslate(String task, @Nullable String sql, SQLException ex) Description copied from class:AbstractFallbackSQLExceptionTranslatorTemplate method for actually translating the given exception.The passed-in arguments will have been pre-checked. Furthermore, this method is allowed to return nullto indicate that no exception match has been found and that fallback translation should kick in.- Specified by:
- doTranslatein class- AbstractFallbackSQLExceptionTranslator
- Parameters:
- task- readable text describing the task being attempted
- sql- the SQL query or update that caused the problem (if known)
- ex- the offending- SQLException
- Returns:
- the DataAccessException, wrapping the SQLException; ornullif no exception match found
 
- 
customTranslate@Nullable protected DataAccessException customTranslate(String task, @Nullable String sql, SQLException sqlEx) Subclasses can override this method to attempt a custom mapping fromSQLExceptiontoDataAccessException.- Parameters:
- task- readable text describing the task being attempted
- sql- the SQL query or update that caused the problem (may be- null)
- sqlEx- the offending SQLException
- Returns:
- nullif no custom translation applies, otherwise a- DataAccessExceptionresulting from custom translation. This exception should include the- sqlExparameter as a nested root cause. This implementation always returns- null, meaning that the translator always falls back to the default error codes.
 
- 
createCustomException@Nullable protected DataAccessException createCustomException(String task, @Nullable String sql, SQLException sqlEx, Class<?> exceptionClass) Create a customDataAccessException, based on a given exception class from aCustomSQLErrorCodesTranslationdefinition.- Parameters:
- task- readable text describing the task being attempted
- sql- the SQL query or update that caused the problem (may be- null)
- sqlEx- the offending SQLException
- exceptionClass- the exception class to use, as defined in the- CustomSQLErrorCodesTranslationdefinition
- Returns:
- nullif the custom exception could not be created, otherwise the resulting- DataAccessException. This exception should include the- sqlExparameter as a nested root cause.
- See Also:
 
 
-