/* * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package javax.sql.rowset; import java.sql.SQLException; /** * An extension of SQLException that provides information * about database warnings set on RowSet objects. * Warnings are silently chained to the object whose method call * caused it to be reported. * This class complements the SQLWarning class. *

* Rowset warnings may be retrieved from JdbcRowSet, * CachedRowSet, * WebRowSet, FilteredRowSet, or JoinRowSet * implementations. To retrieve the first warning reported on any * RowSet * implementation, use the method getRowSetWarnings defined * in the JdbcRowSet interface or the CachedRowSet * interface. To retrieve a warning chained to the first warning, use the * RowSetWarning method * getNextWarning. To retrieve subsequent warnings, call * getNextWarning on each RowSetWarning object that is * returned. *

* The inherited methods getMessage, getSQLState, * and getErrorCode retrieve information contained in a * RowSetWarning object. * * @since 1.5 */ public class RowSetWarning extends SQLException { /** * Constructs a RowSetWarning object * with the given value for the reason; SQLState defaults to null, * and vendorCode defaults to 0. * * @param reason a String object giving a description * of the warning; if the String is null, * this constructor behaves like the default (zero parameter) * RowSetWarning constructor */ public RowSetWarning(String reason) { super(reason); } /** * Constructs a default RowSetWarning object. The reason * defaults to null, SQLState defaults to null and vendorCode * defaults to 0. */ public RowSetWarning() { super(); } /** * Constructs a RowSetWarning object initialized with the * given values for the reason and SQLState. The vendor code defaults to 0. * * If the reason or SQLState parameters are null, * this constructor behaves like the default (zero parameter) * RowSetWarning constructor. * * @param reason a String giving a description of the * warning; * @param SQLState an XOPEN code identifying the warning; if a non standard * XOPEN SQLState is supplied, no exception is thrown. */ public RowSetWarning(java.lang.String reason, java.lang.String SQLState) { super(reason, SQLState); } /** * Constructs a fully specified RowSetWarning object initialized * with the given values for the reason, SQLState and vendorCode. * * If the reason, or the SQLState * parameters are null, this constructor behaves like the default * (zero parameter) RowSetWarning constructor. * * @param reason a String giving a description of the * warning; * @param SQLState an XOPEN code identifying the warning; if a non standard * XOPEN SQLState is supplied, no exception is thrown. * @param vendorCode a database vendor-specific warning code */ public RowSetWarning(java.lang.String reason, java.lang.String SQLState, int vendorCode) { super(reason, SQLState, vendorCode); } /** * Retrieves the warning chained to this RowSetWarning * object. * * @return the RowSetWarning object chained to this one; if no * RowSetWarning object is chained to this one, * null is returned (default value) * @see #setNextWarning */ public RowSetWarning getNextWarning() { SQLException warning = getNextException(); if ( warning == null || warning instanceof RowSetWarning) { return (RowSetWarning)warning; } else { // The chained value isn't a RowSetWarning. // This is a programming error by whoever added it to // the RowSetWarning chain. We throw a Java "Error". throw new Error("RowSetWarning chain holds value that is not a RowSetWarning: "); } } /** * Sets warning as the next warning, that is, the warning chained * to this RowSetWarning object. * * @param warning the RowSetWarning object to be set as the * next warning; if the RowSetWarning is null, this * represents the finish point in the warning chain * @see #getNextWarning */ public void setNextWarning(RowSetWarning warning) { setNextException(warning); } static final long serialVersionUID = 6678332766434564774L; }