Clob.java 6.85 KB
Newer Older
Tom Tromey committed
1
/* Clob.java -- Access Character Large OBjects
2
   Copyright (C) 1999, 2000, 2002, 2006 Free Software Foundation, Inc.
Tom Tromey committed
3 4 5 6 7 8 9

This file is part of GNU Classpath.

GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
10

Tom Tromey committed
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
GNU Classpath 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 for more details.

You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING.  If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.

Linking this library statically or dynamically with other modules is
making a combined work based on this library.  Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.

As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module.  An independent module is a module which is not derived from
or based on this library.  If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so.  If you do not wish to do so, delete this
exception statement from your version. */

38

Tom Tromey committed
39 40 41 42 43 44 45 46
package java.sql;

import java.io.InputStream;
import java.io.OutputStream;
import java.io.Reader;
import java.io.Writer;

/**
47 48
 * This interface contains methods for accessing a SQL CLOB (Character Large
 * OBject) type.
49
 *
Tom Tromey committed
50 51
 * @author Aaron M. Renn (arenn@urbanophile.com)
 */
52
public interface Clob
Tom Tromey committed
53
{
54 55
  /**
   * This method returns the number of characters in this <code>Clob</code>.
56
   *
57 58 59 60
   * @return The number of characters in this <code>Clob</code>.
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
Tom Tromey committed
61 62 63
  long length() throws SQLException;

  /**
64 65
   * This method returns the specified portion of this <code>Clob</code> as a
   * <code>String</code>.
66
   *
67 68 69 70
   * @param start The index into this <code>Clob</code> (index values
   *              start at 1) to start returning characters from.
   * @param count The requested number of characters to return.
   * @return The requested <code>Clob</code> section, as a <code>String</code>.
Tom Tromey committed
71 72 73
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
74
  String getSubString(long start, int count) throws SQLException;
Tom Tromey committed
75 76

  /**
77 78
   * This method returns a character stream that reads the contents of this
   * <code>Clob</code>.
79
   *
80
   * @return A character stream to read this <code>Clob</code>'s contents.
Tom Tromey committed
81 82 83 84 85 86
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
  Reader getCharacterStream() throws SQLException;

  /**
87 88
   * This method returns a byte stream that reads the contents of this
   * <code>Clob</code> as a series of ASCII bytes.
89
   *
90
   * @return A stream to read this <code>Clob</code>'s contents.
Tom Tromey committed
91 92 93 94 95 96
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
  InputStream getAsciiStream() throws SQLException;

  /**
97 98 99
   * This method returns the index into this <code>Clob</code> of the first
   * occurrence of the specified character pattern (supplied by the caller as a
   * <code>String</code>). The search begins at the specified index.
100
   *
101 102 103 104 105 106
   * @param pattern The character pattern to search for, passed as a
   *                <code>String</code>.
   * @param start The index into this <code>Clob</code> to start searching
   *              (indices start at 1).
   * @return The index at which the pattern was found (indices start at 1), or
   *         -1 if the pattern was not found.
Tom Tromey committed
107 108 109
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
110
  long position(String pattern, long start) throws SQLException;
Tom Tromey committed
111 112

  /**
113 114 115
   * This method returns the index into this <code>Clob</code> of the first
   * occurrence of the specified character pattern (supplied by the caller as a
   * <code>Clob</code>). The search begins at the specified index.
116
   *
117 118 119 120 121 122
   * @param pattern The character pattern to search for, passed as a
   *                <code>Clob</code>.
   * @param start The index into this <code>Clob</code> to start searching
   *              (indices start at 1).
   * @return The index at which the pattern was found (indices start at 1), or
   *         -1 if the pattern was not found.
Tom Tromey committed
123 124 125
   * @exception SQLException If an error occurs.
   * @since 1.2
   */
126
  long position(Clob pattern, long start) throws SQLException;
Tom Tromey committed
127 128

  /**
129 130
   * Writes the specified string into this <code>Clob</code>, starting at the
   * specified index.
131
   *
132 133 134 135
   * @param start The index at which the writing starts.
   * @param value The string to write.
   * @return The number of characters written.
   * @exception SQLException If an error occurs.
Tom Tromey committed
136 137
   * @since 1.4
   */
138
  int setString(long start, String value) throws SQLException;
Tom Tromey committed
139 140

  /**
141 142
   * Writes the specified portion of a string into this <code>Clob</code>,
   * starting at the specified index.
143
   *
144 145 146 147 148 149 150
   * @param startWrite The index at which the writing starts.
   * @param value The string to write a portion of.
   * @param startRead The offset into the string where the portion to copy
   *                  starts.
   * @param count The number of characters to write.
   * @return The number of characters written.
   * @exception SQLException If an error occurs.
Tom Tromey committed
151 152
   * @since 1.4
   */
153 154
  int setString(long startWrite, String value, int startRead, int count)
      throws SQLException;
Tom Tromey committed
155 156

  /**
157 158
   * Returns an ASCII text stream that writes into this <code>Clob</code>,
   * starting at the specified index.
159
   *
160 161 162
   * @param start The index at which the writing starts.
   * @return An ASCII text stream to write into this <code>Clob</code>.
   * @exception SQLException If an error occurs.
Tom Tromey committed
163 164
   * @since 1.4
   */
165
  OutputStream setAsciiStream(long start) throws SQLException;
Tom Tromey committed
166 167

  /**
168 169
   * Returns a character stream that writes into this <code>Clob</code>,
   * starting at the specified index.
170
   *
171 172 173
   * @param start The index at which the writing starts.
   * @return A character stream to write into this <code>Clob</code>.
   * @exception SQLException If an error occurs.
Tom Tromey committed
174 175
   * @since 1.4
   */
176
  Writer setCharacterStream(long start) throws SQLException;
Tom Tromey committed
177 178

  /**
179 180
   * Truncates this <code>Clob</code> to be at most the specified number of
   * characters long.
181
   *
182 183
   * @param count The length this <code>Clob</code> is truncated to.
   * @exception SQLException If an error occurs.
Tom Tromey committed
184 185
   * @since 1.4
   */
186
  void truncate(long count) throws SQLException;
Tom Tromey committed
187
}