summaryrefslogtreecommitdiff
path: root/java/sql
diff options
context:
space:
mode:
authorAaron M. Renn <arenn@urbanophile.com>1999-01-12 04:03:00 +0000
committerAaron M. Renn <arenn@urbanophile.com>1999-01-12 04:03:00 +0000
commit941cf75497f9d0e2a981f22c7207c9cfa6e6c309 (patch)
tree4698d7ed4fa158f48f100ecd26a2fb1c670557cb /java/sql
parent497c3ec2cc773ecd0d60b81be5077b5fa2098ce0 (diff)
downloadclasspath-941cf75497f9d0e2a981f22c7207c9cfa6e6c309.tar.gz
Initial Checkin
Diffstat (limited to 'java/sql')
-rw-r--r--java/sql/BatchUpdateException.java164
-rw-r--r--java/sql/DataTruncation.java179
-rw-r--r--java/sql/SQLException.java193
-rw-r--r--java/sql/SQLWarning.java130
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
+