001/*
002 * Copyright 2002-2012 the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *      https://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017package org.springframework.jdbc;
018
019import java.sql.SQLException;
020
021import org.springframework.dao.UncategorizedDataAccessException;
022
023/**
024 * Exception thrown when we can't classify a SQLException into
025 * one of our generic data access exceptions.
026 *
027 * @author Rod Johnson
028 * @author Juergen Hoeller
029 */
030@SuppressWarnings("serial")
031public class UncategorizedSQLException extends UncategorizedDataAccessException {
032
033        /** SQL that led to the problem */
034        private final String sql;
035
036
037        /**
038         * Constructor for UncategorizedSQLException.
039         * @param task name of current task
040         * @param sql the offending SQL statement
041         * @param ex the root cause
042         */
043        public UncategorizedSQLException(String task, String sql, SQLException ex) {
044                super(task + "; uncategorized SQLException for SQL [" + sql + "]; SQL state [" +
045                                ex.getSQLState() + "]; error code [" + ex.getErrorCode() + "]; " + ex.getMessage(), ex);
046                this.sql = sql;
047        }
048
049
050        /**
051         * Return the underlying SQLException.
052         */
053        public SQLException getSQLException() {
054                return (SQLException) getCause();
055        }
056
057        /**
058         * Return the SQL that led to the problem.
059         */
060        public String getSql() {
061                return this.sql;
062        }
063
064}