⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sqlstateconverter.java

📁 一个Java持久层类库
💻 JAVA
字号:
// $Id: SQLStateConverter.java 9557 2006-03-06 15:16:27Z steve.ebersole@jboss.com $package org.hibernate.exception;import org.hibernate.JDBCException;import java.sql.SQLException;import java.util.HashSet;import java.util.Set;/** * A SQLExceptionConverter implementation which performs converion based on * the underlying SQLState. Interpretation of a SQL error based on SQLState * is not nearly as accurate as using the ErrorCode (which is, however, vendor- * specific).  Use of a ErrorCode-based converter should be preferred approach * for converting/interpreting SQLExceptions. * * @author Steve Ebersole */public class SQLStateConverter implements SQLExceptionConverter {	private ViolatedConstraintNameExtracter extracter;	private static final Set SQL_GRAMMAR_CATEGORIES = new HashSet();	private static final Set DATA_CATEGORIES = new HashSet();	private static final Set INTEGRITY_VIOLATION_CATEGORIES = new HashSet();	private static final Set CONNECTION_CATEGORIES = new HashSet();	static {		SQL_GRAMMAR_CATEGORIES.add( "07" );		SQL_GRAMMAR_CATEGORIES.add( "37" );		SQL_GRAMMAR_CATEGORIES.add( "42" );		SQL_GRAMMAR_CATEGORIES.add( "65" );		SQL_GRAMMAR_CATEGORIES.add( "S0" );		SQL_GRAMMAR_CATEGORIES.add( "20" );				DATA_CATEGORIES.add("22");		DATA_CATEGORIES.add("21");		DATA_CATEGORIES.add("02");		INTEGRITY_VIOLATION_CATEGORIES.add( "23" );		INTEGRITY_VIOLATION_CATEGORIES.add( "27" );		INTEGRITY_VIOLATION_CATEGORIES.add( "44" );		CONNECTION_CATEGORIES.add( "08" );	}	public SQLStateConverter(ViolatedConstraintNameExtracter extracter) {		this.extracter = extracter;	}	/**	 * Convert the given SQLException into Hibernate's JDBCException hierarchy.	 *	 * @param sqlException The SQLException to be converted.	 * @param message      An optional error message.	 * @param sql          Optionally, the sql being performed when the exception occurred.	 * @return The resulting JDBCException.	 */	public JDBCException convert(SQLException sqlException, String message, String sql) {		String sqlState = JDBCExceptionHelper.extractSqlState( sqlException );		if ( sqlState != null ) {			String sqlStateClassCode = JDBCExceptionHelper.determineSqlStateClassCode( sqlState );			if ( sqlStateClassCode != null ) {				if ( SQL_GRAMMAR_CATEGORIES.contains( sqlStateClassCode ) ) {					return new SQLGrammarException( message, sqlException, sql );				}				else if ( INTEGRITY_VIOLATION_CATEGORIES.contains( sqlStateClassCode ) ) {					String constraintName = extracter.extractConstraintName( sqlException );					return new ConstraintViolationException( message, sqlException, sql, constraintName );				}				else if ( CONNECTION_CATEGORIES.contains( sqlStateClassCode ) ) {					return new JDBCConnectionException( message, sqlException, sql );				}				else if ( DATA_CATEGORIES.contains( sqlStateClassCode ) ) {					return new DataException( message, sqlException, sql );				}			}			if ( "40001".equals( sqlState ) ) {				return new LockAcquisitionException( message, sqlException, sql );			}			if ( "61000".equals( sqlState ) ) {				// oracle sql-state code for deadlock				return new LockAcquisitionException( message, sqlException, sql );			}		}		return handledNonSpecificException( sqlException, message, sql );	}	/**	 * Handle an exception not converted to a specific type based on the SQLState.	 *	 * @param sqlException The exception to be handled.	 * @param message      An optional message	 * @param sql          Optionally, the sql being performed when the exception occurred.	 * @return The converted exception; should <b>never</b> be null.	 */	protected JDBCException handledNonSpecificException(SQLException sqlException, String message, String sql) {		return new GenericJDBCException( message, sqlException, sql );	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -