diff options
| author | Aaron M. Renn <arenn@urbanophile.com> | 1999-01-12 04:03:00 +0000 |
|---|---|---|
| committer | Aaron M. Renn <arenn@urbanophile.com> | 1999-01-12 04:03:00 +0000 |
| commit | 941cf75497f9d0e2a981f22c7207c9cfa6e6c309 (patch) | |
| tree | 4698d7ed4fa158f48f100ecd26a2fb1c670557cb /java/sql | |
| parent | 497c3ec2cc773ecd0d60b81be5077b5fa2098ce0 (diff) | |
| download | classpath-941cf75497f9d0e2a981f22c7207c9cfa6e6c309.tar.gz | |
Initial Checkin
Diffstat (limited to 'java/sql')
| -rw-r--r-- | java/sql/BatchUpdateException.java | 164 | ||||
| -rw-r--r-- | java/sql/DataTruncation.java | 179 | ||||
| -rw-r--r-- | java/sql/SQLException.java | 193 | ||||
| -rw-r--r-- | java/sql/SQLWarning.java | 130 |
4 files changed, 666 insertions, 0 deletions
diff --git a/java/sql/BatchUpdateException.java b/java/sql/BatchUpdateException.java new file mode 100644 index 000000000..b9a1b1aba --- /dev/null +++ b/java/sql/BatchUpdateException.java @@ -0,0 +1,164 @@ +/************************************************************************* +/* BatchUpdateException.java -- Exception for batch oriented SQL errors +/* +/* Copyright (c) 1999 Free Software Foundation, Inc. +/* Written by Aaron M. Renn (arenn@urbanophile.com) +/* +/* This library is free software; you can redistribute it and/or modify +/* it under the terms of the GNU Library General Public License as published +/* by the Free Software Foundation, either version 2 of the License, or +/* (at your option) any later verion. +/* +/* This library 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 Library General Public License for more details. +/* +/* You should have received a copy of the GNU Library General Public License +/* along with this library; if not, write to the Free Software Foundation +/* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307 USA +/*************************************************************************/ + +package java.sql; + +/** + * This class extends <code>SQLException</code> to count the successful + * updates in each statement in a batch that was successfully updated prior + * to the error. + * + * @author Aaron M. Renn (arenn@urbanophile.com) + */ +public class BatchUpdateException extends SQLException + implements java.io.Serializable +{ + +/*************************************************************************/ + +/* + * Instance Variables + */ + +/** + * This is the array of update counts for the commands which completed + * successfully prior to the error. + * @serialized + */ +private int[] updateCounts; + +/*************************************************************************/ + +/* + * Constructors + */ + +/** + * This method initializes a new instance of <code>BatchUpdateException</code> + * with no descriptive error message. The SQL state and update count will + * be initialized to <code>null</code> and the vendor specific error code will + * initialized to 0. + */ +public +BatchUpdateException() +{ + super(); +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>BatchUpdateException</code> + * with the specified update count information and no descriptive error + * message. This SQL state will be initialized to <code>null</code> and + * the vendor specific error code will be initialized to 0. + * + * @param updateCounts The update count array. + */ +public +BatchUpdateException(int[] updateCounts) +{ + super(); + + this.updateCounts = updateCounts; +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>BatchUpdateException</code> + * with the specified descriptive error message and update count information. + * The SQL state will be initialized to <code>null</code> and the vendor + * specific error code will be initialized to 0. + * + * @param message The descriptive error message. + * @param updateCounts The update count information for this error. + */ +public +BatchUpdateException(String message, int[] updateCounts) +{ + super(message); + + this.updateCounts = updateCounts; +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>BatchUpdateException</code> + * with the specified descriptive error message, SQL state, and update count + * information. The vendor specific error code will be initialized to 0. + * + * @param message The descriptive error message. + * @param SQLState The SQL state information for this error. + * @param updateCounts The update count information for this error. + */ +public +BatchUpdateException(String message, String SQLState, int[] updateCounts) +{ + super(message, SQLState); + + this.updateCounts = updateCounts; +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>BatchUpdateException</code> + * with the specified descriptive error message, SQL state, vendor + * specific error code and update count information. + * + * @param message The descriptive error message. + * @param SQLState The SQL state information for this error. + * @param vendorCode The vendor specific error code for this error. + * @param updateCounts The update count information for this error. + */ +public +BatchUpdateException(String message, String SQLState, int vendorCode, + int[] updateCounts) +{ + super(message, SQLState, vendorCode); + + this.updateCounts = updateCounts; +} + +/*************************************************************************/ + +/* + * Instance Methods + */ + +/** + * This method returns the update count information for this error. If + * not <code>null</code> this is an array of <code>int</code>'s that are + * the update accounts for each command that was successfully executed. + * The array elements are in the order that the commands were executed. + * + * @return The update count information, which may be <code>null</code>. + */ +public int[] +getUpdateCounts() +{ + return(updateCounts); +} + +} // class BatchUpdateException + diff --git a/java/sql/DataTruncation.java b/java/sql/DataTruncation.java new file mode 100644 index 000000000..4e58c201e --- /dev/null +++ b/java/sql/DataTruncation.java @@ -0,0 +1,179 @@ +/************************************************************************* +/* DataTruncation.java -- Warning when data has been truncated. +/* +/* Copyright (c) 1999 Free Software Foundation, Inc. +/* Written by Aaron M. Renn (arenn@urbanophile.com) +/* +/* This library is free software; you can redistribute it and/or modify +/* it under the terms of the GNU Library General Public License as published +/* by the Free Software Foundation, either version 2 of the License, or +/* (at your option) any later verion. +/* +/* This library 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 Library General Public License for more details. +/* +/* You should have received a copy of the GNU Library General Public License +/* along with this library; if not, write to the Free Software Foundation +/* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307 USA +/*************************************************************************/ + +package java.sql; + +/** + * This exception is thrown when a piece of data is unexpectedly + * truncated in JDBC. + * + * @author Aaron M. Renn (arenn@urbanophile.com) + */ +public class DataTruncation extends SQLWarning implements java.io.Serializable +{ + +/*************************************************************************/ + +/* + * Instance Variables + */ + +/** + * The original size of the data. + * @serialized + */ +private int dataSize; + +/** + * The index of the parameter or column whose value was truncated. + * @serialized + */ +private int index; + +/** + * Indicates whether or not a parameter value was truncated. + * @serialized + */ +private boolean parameter; + +/** + * Indicates whether or not a data column value was truncated. + * @serialized + */ +private boolean read; + +/** + * This is the size of the data after truncation. + * @serialized + */ +private int transferSize; + +/*************************************************************************/ + +/* + * Constructors + */ + +/** + * This method initializes a new instance of <code>DataTruncation</code> + * with the specified values. The descriptive error message for this + * exception will be "Data truncation", the SQL state will be "01004" + * and the vendor specific error code will be set to 0. + * + * @param index The index of the parameter or column that was truncated. + * @param parameter <code>true</code> if a parameter was truncated, + * <code>false</code> otherwise. + * @param read <code>true</code> if a data column was truncated, + * <code>false</code> otherwise. + * @param dataSize The original size of the data. + * @param transferSize The size of the data after truncation. + */ +public +DataTruncation(int index, boolean parameter, boolean read, int dataSize, + int transferSize) +{ + super("Data truncation", "01004"); + + this.index = index; + this.parameter = parameter; + this.read = read; + this.dataSize = dataSize; + this.transferSize = transferSize; +} + +/*************************************************************************/ + +/* + * Instance Methods + */ + +/** + * This method returns the index of the column or parameter that was + * truncated. + * + * @return The index of the column or parameter that was truncated. + */ +public int +getIndex() +{ + return(index); +} + +/*************************************************************************/ + +/** + * This method determines whether or not it was a parameter that was + * truncated. + * + * @return <code>true</code> if a parameter was truncated, <code>false</code> + * otherwise. + */ +public boolean +getParameter() +{ + return(parameter); +} + +/*************************************************************************/ + +/** + * This method determines whether or not it was a column that was + * truncated. + * + * @return <code>true</code> if a column was truncated, <code>false</code> + * otherwise. + */ +public boolean +getRead() +{ + return(read); +} + +/*************************************************************************/ + +/** + * This method returns the original size of the parameter or column that + * was truncated. + * + * @return The original size of the parameter or column that was truncated. + */ +public int +getDataSize() +{ + return(dataSize); +} + +/*************************************************************************/ + +/** + * This method returns the size of the parameter or column after it was + * truncated. + * + * @return The size of the parameter or column after it was truncated. + */ +public int +getTransferSize() +{ + return(transferSize); +} + +} // class DataTruncation + diff --git a/java/sql/SQLException.java b/java/sql/SQLException.java new file mode 100644 index 000000000..d714d7d33 --- /dev/null +++ b/java/sql/SQLException.java @@ -0,0 +1,193 @@ +/************************************************************************* +/* SQLException.java -- General SQL exception +/* +/* Copyright (c) 1999 Free Software Foundation, Inc. +/* Written by Aaron M. Renn (arenn@urbanophile.com) +/* +/* This library is free software; you can redistribute it and/or modify +/* it under the terms of the GNU Library General Public License as published +/* by the Free Software Foundation, either version 2 of the License, or +/* (at your option) any later verion. +/* +/* This library 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 Library General Public License for more details. +/* +/* You should have received a copy of the GNU Library General Public License +/* along with this library; if not, write to the Free Software Foundation +/* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307 USA +/*************************************************************************/ + +package java.sql; + +/** + * This exception is thrown when a database error occurs. + * + * @author Aaron M. Renn (arenn@urbanophile.com) + */ +public class SQLException extends Exception implements java.io.Serializable +{ + +/*************************************************************************/ + +/* + * Instance Variables + */ + +/** + * This is the next exception in the chain + * @serialized + */ +private SQLException next; + +/** + * This is the state of the SQL statement at the time of the error. + * @serialized + */ +private String SQLState; + +/** + * The vendor error code for this error + * @serialized + */ +private int vendorCode; + +/*************************************************************************/ + +/* + * Constructors + */ + +/** + * This method initializes a new instance of <code>SQLException</code> + * that does not have a descriptive messages and SQL state, and which + * has a vendor error code of 0. + */ +public +SQLException() +{ + this(null, null, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>SQLException</code> + * with the specified descriptive error message. The SQL state of this + * instance will be <code>null</code> and the vendor error code will be 0. + * + * @param message A string describing the nature of the error. + */ +public +SQLException(String message) +{ + this(message, null, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>SQLException</code> + * with the specified descriptive error message and SQL state string. + * The vendor error code of this instance will be 0. + * + * @param message A string describing the nature of the error. + * @param SQLState A string containing the SQL state of the error. + */ +public +SQLException(String message, String SQLState) +{ + this(message, SQLState, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a nwe instance of <code>SQLException</code> + * with the specified descriptive error message, SQL state string, and + * vendor code. + * + * @param message A string describing the nature of the error. + * @param SQLState A string containing the SQL state of the error. + * @param vendorCode The vendor error code associated with this error. + */ +public +SQLException(String message, String SQLState, int vendorCode) +{ + super(message); + + this.SQLState = SQLState; + this.vendorCode = vendorCode; +} + +/*************************************************************************/ + +/* + * Instance Methods + */ + +/** + * This method returns the SQLState information associated with this + * error. The value returned is a <code>String</code> which is formatted + * using the XOPEN SQL state conventions. + * + * @return The SQL state, which may be <code>null</code>. + */ +public String +getSQLState() +{ + return(SQLState); +} + +/*************************************************************************/ + +/** + * This method returns the vendor specific error code associated with + * this error. + * + * @return The vendor specific error code associated with this error. + */ +public int +getErrorCode() +{ + return(vendorCode); +} + +/*************************************************************************/ + +/** + * This method returns the exception that is chained to this object. + * + * @return The exception chained to this object, which may be + * <code>null</code>. + */ +public SQLException +getNextException() +{ + return(next); +} + +/*************************************************************************/ + +/** + * This method adds a new exception to the end of the chain of exceptions + * that are chained to this object. + * + * @param e The exception to add to the end of the chain. + */ +public void +setNextException(SQLException e) +{ + if (e == null) + return; + + SQLException list_entry = this; + while (list_entry.getNextException() != null) + list_entry = list_entry.getNextException(); + + list_entry.next = e; +} + +} // class SQLException + diff --git a/java/sql/SQLWarning.java b/java/sql/SQLWarning.java new file mode 100644 index 000000000..0eb3c0b56 --- /dev/null +++ b/java/sql/SQLWarning.java @@ -0,0 +1,130 @@ +/************************************************************************* +/* SQLWarning.java -- Database access warnings. +/* +/* Copyright (c) 1999 Free Software Foundation, Inc. +/* Written by Aaron M. Renn (arenn@urbanophile.com) +/* +/* This library is free software; you can redistribute it and/or modify +/* it under the terms of the GNU Library General Public License as published +/* by the Free Software Foundation, either version 2 of the License, or +/* (at your option) any later verion. +/* +/* This library 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 Library General Public License for more details. +/* +/* You should have received a copy of the GNU Library General Public License +/* along with this library; if not, write to the Free Software Foundation +/* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307 USA +/*************************************************************************/ + +package java.sql; + +/** + * This exception is thrown when a database warning occurs. + * + * @author Aaron M. Renn (arenn@urbanophile.com) + */ +public class SQLWarning extends SQLException implements java.io.Serializable +{ + +/*************************************************************************/ + +/* + * Constructors + */ + +/** + * This method initializes a new instance of <code>SQLWxception</code> + * that does not have a descriptive messages and SQL state, and which + * has a vendor error code of 0. + */ +public +SQLWarning() +{ + this(null, null, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>SQLWarning</code> + * with the specified descriptive error message. The SQL state of this + * instance will be <code>null</code> and the vendor error code will be 0. + * + * @param message A string describing the nature of the error. + */ +public +SQLWarning(String message) +{ + this(message, null, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a new instance of <code>SQLWarning</code> + * with the specified descriptive error message and SQL state string. + * The vendor error code of this instance will be 0. + * + * @param message A string describing the nature of the error. + * @param SQLState A string containing the SQL state of the error. + */ +public +SQLWarning(String message, String SQLState) +{ + this(message, SQLState, 0); +} + +/*************************************************************************/ + +/** + * This method initializes a nwe instance of <code>SQLWarning</code> + * with the specified descriptive error message, SQL state string, and + * vendor code. + * + * @param message A string describing the nature of the error. + * @param SQLState A string containing the SQL state of the error. + * @param vendorCode The vendor error code associated with this error. + */ +public +SQLWarning(String message, String SQLState, int vendorCode) +{ + super(message, SQLState, vendorCode); +} + +/*************************************************************************/ + +/* + * Instance Methods + */ + +/** + * This method returns the exception that is chained to this object. + * + * @return The exception chained to this object, which may be + * <code>null</code>. + */ +public SQLWarning +getNextWarning() +{ + return((SQLWarning)super.getNextException()); +} + +/*************************************************************************/ + +/** + * This method adds a new exception to the end of the chain of exceptions + * that are chained to this object. + * + * @param e The exception to add to the end of the chain. + */ +public void +setNextWarning(SQLWarning e) +{ + super.setNextException(e); +} + +} // class SQLWarning + |
