Package oracle.sql

Class BLOB

  • All Implemented Interfaces:
    Serializable, Blob, oracle.jdbc.internal.ACProxyable, oracle.jdbc.internal.OracleBlob, oracle.jdbc.internal.OracleConcreteProxy, oracle.jdbc.internal.OracleDatumWithConnection, oracle.jdbc.internal.OracleLargeObject, OracleBlob

    public class BLOB
    extends DatumWithConnection
    implements oracle.jdbc.internal.OracleBlob, oracle.jdbc.internal.OracleConcreteProxy
    Deprecated.
    Use java.sql.Blob interface for declaration instead of using concrete class oracle.sql.BLOB.
    This class implements the java.sql.Blob interface in JDBC 2.0. It provides the native implementation of the Blob methods. Use Blob interface for declaration instead of using concrete class oracle.sql.BLOB. java.sql.Blob has methods declared for all opertions. For Oracle specific methods use the interface OracleBlob.

    Obtaining Blob from ResultSet

    java.sql.Blob blob = resultSet.getBlob(...);

    Creating temporary Blob from factory method, Connection

    java.sql.Blob blob = connection.createBlob();
    See Also:
    Blob, OracleBlob, Connection.createBlob(), Serialized Form
    • Field Detail

      • MAX_CHUNK_SIZE

        public static final int MAX_CHUNK_SIZE
        Deprecated.
        1907584: Changed MAX_CHUNK_SIZE from 32512 to 32768. This was done to accommodate larger DB_BLOCK_SIZEs. Using 32512 would cause getBufferSize() to return 32512 for DB_BLOCK_SIZEs from 8192-32768. For these block sizes getBufferSize() should return getChunkSize(); not 32512. By using 32768 as the MAX_CHUNK_SIZE, getBufferSize() returns the correct chunk size. Please see bug for details.
        See Also:
        Constant Field Values
      • OLD_WRONG_DURATION_SESSION

        public static final int OLD_WRONG_DURATION_SESSION
        Deprecated.
        See Also:
        Constant Field Values
      • OLD_WRONG_DURATION_CALL

        public static final int OLD_WRONG_DURATION_CALL
        Deprecated.
        See Also:
        Constant Field Values
      • target

        protected oracle.jdbc.driver.OracleBlob target
        Deprecated.
    • Constructor Detail

      • BLOB

        protected BLOB()
        Deprecated.
      • BLOB

        protected BLOB​(oracle.jdbc.driver.OracleBlob b)
        Deprecated.
        Call from empty lob static method
    • Method Detail

      • getTarget

        public oracle.jdbc.driver.OracleBlob getTarget()
        Deprecated.
      • length

        public long length()
                    throws SQLException
        Deprecated.
        Implements the Blob interface function. Return the length of the Binary Large OBject in bytes.
        Specified by:
        length in interface Blob
        Returns:
        length of the BLOB in bytes
        Throws:
        SQLException
      • publisherOracle

        public final Flow.Publisher<byte[]> publisherOracle​(long position)
                                                     throws SQLException
        Deprecated.
        Description copied from interface: OracleBlob
        Returns a Publisher that publishes the content of this Blob beginning at the specified position. The argument to each call to Subscriber.onNext will contain an implementation defined number of bytes.

        Calling any method of this Blob except isEmptyLob(), isSecureFile(), isTemporary(), or one defined by Object between the time this method is called and the time when the returned publisher terminates will block.

        The returned publisher terminates once all subscribers have received Subscriber.onComplete, received Subscriber.onError, or cancelled their subscription.

        Asynchronous tasks initiated by this method will execute under the current AccessControlContext of the calling thread.

        Specified by:
        publisherOracle in interface OracleBlob
        Parameters:
        position - the position at which to start reading from the BLOB value that this Blob object represents; The first position is 1
        Returns:
        a Publisher of the content of this Blob
        Throws:
        SQLException - if a database error occurs, or if this method is called on a Blob that has been freed, or if position is less than 1
      • subscriberOracle

        public final Flow.Subscriber<byte[]> subscriberOracle​(long position)
                                                       throws SQLException
        Deprecated.
        Description copied from interface: OracleBlob
        Returns a Subscriber that will append the published bytes to this Blob beginning at the specified position.

        Calling any method of this Blob except isEmptyLob(), isSecureFile(), isTemporary(), or one defined by Object between the time this method is called and the time when the returned Subscriber terminates will block.

        The returned Subscriber terminates once Subscriber.onComplete is received, Subscriber.onError is received, or its subscription is cancelled.

        Asynchronous tasks initiated by this method will execute under the current AccessControlContext of the calling thread.

        Specified by:
        subscriberOracle in interface OracleBlob
        Parameters:
        position - the position at which to start reading from the BLOB value that this Blob object represents; The first position is 1
        Returns:
        a Subscriber that appends bytes to this Blob
        Throws:
        SQLException - if a database error occurs, or if this method is called on a Blob that has been freed, or if position is less than 1
      • subscriberOracle

        public final Flow.Subscriber<byte[]> subscriberOracle​(long position,
                                                              Flow.Subscriber<Long> outcomeSubscriber)
                                                       throws SQLException
        Deprecated.
        Description copied from interface: OracleBlob
        Returns a Subscriber that will append the published bytes to this Blob beginning at the specified position.

        Calling any method of this Blob except isEmptyLob(), isSecureFile(), isTemporary(), or one defined by Object between the time this method is called and the time when the returned Subscriber terminates will block.

        The returned Subscriber terminates once Subscriber.onComplete is received, Subscriber.onError is received, or its subscription is cancelled.

        The outcome of writing published bytes to the BLOB value that this Blob object represents is published to the outcomeSubscriber:

        • The outcomeSubscriber receives an onNext signal each time a write to the BLOB value is successful. The number of bytes transferred in each successful write is the argument to each invocation of onNext.
        • The outcomeSubscriber receives an onComplete signal after the last published byte has been written successfully.
        • The outcomeSubscriber receives an onError signal with a SQLException if a failure occurs when writing published bytes.

        The outcomeSubscriber must signal demand in order to receive any of the signals listed above. If more than Flow.defaultBufferSize() writes have succeeded without demand from the outcomeSubscriber, then the returned subscriber will not signal further demand until the outcomeSubscriber has also signalled demand.

        The number of writes used to transfer published bytes to the BLOB value is implementation defined, and may be different from the number of byte arrays published to the returned Subscriber.

        Asynchronous tasks initiated by this method will execute under the current AccessControlContext of the calling thread.

        Specified by:
        subscriberOracle in interface OracleBlob
        Parameters:
        position - the position at which to start reading from the BLOB value that this Blob object represents; The first position is 1
        outcomeSubscriber - a Subscriber of write outcomes.
        Returns:
        a Subscriber that appends bytes to this Blob
        Throws:
        SQLException - if a database error occurs, or if this method is called on a Blob that has been freed, or if position is less than 1
      • freeAsyncOracle

        public final Flow.Publisher<Void> freeAsyncOracle()
                                                   throws SQLException
        Deprecated.
        Returns a Publisher that publishes the result of freeing the Blob object and the resources that it holds. The object is invalid after the returned Publisher terminates with onComplete.

        After the returned Publisher terminates with onComplete, any attempt to invoke a method other than Blob.free() or freeAsyncOracle will result in an SQLException being thrown. Calling freeAsyncOracle on a Blob object that has already been freed is treated as a no-op.

        Calling any method of this Blob except isEmptyLob(), isSecureFile(), isTemporary(), or one defined by Object between the time this method is called and the time when the returned Subscriber terminates will block.

        The returned publisher terminates once all subscribers have received Subscriber.onComplete, received Subscriber.onError, or cancelled their subscription.

        The returned publisher will only emit onComplete or onError; No items are emitted to onNext.

        Asynchronous tasks initiated by this method will execute under the current AccessControlContext of the calling thread.

        Implements the Reactive Extensions API by delegating to the ojiOracleBlob's implemenation.

        Specified by:
        freeAsyncOracle in interface OracleBlob
        Returns:
        a Publisher of the result of freeing this Blob
        Throws:
        SQLException - if a database error occurs
      • getBytes

        public byte[] getBytes​(long pos,
                               int length)
                        throws SQLException
        Deprecated.
        Implements the Blob interface function. Return a copy of the contents of the BLOB at the requested position.
        Specified by:
        getBytes in interface Blob
        Parameters:
        pos - is the first byte of the blob to be extracted.
        length - is the number of consecutive bytes to be copied.
        Returns:
        a byte array containing a portion of the BLOB If the pos argument is larger than the length of the data the result is null. If the pos argument is less than the length of the data, but the sum of pos argument and the length is greater than the length of the data, the result will be smaller than the length requested. If the length is zero return and empty array
        Throws:
        SQLException
      • getBinaryStream

        public InputStream getBinaryStream()
                                    throws SQLException
        Deprecated.
        Implements the Blob interface function. Retrieve the entire BLOB as a stream.
        Specified by:
        getBinaryStream in interface Blob
        Returns:
        a stream containing the BLOB data
        Throws:
        SQLException
      • getBinaryStream

        public InputStream getBinaryStream​(boolean isInternal)
                                    throws SQLException
        Deprecated.
        Implements the Blob interface function. Retrieve the entire BLOB as a stream.
        Returns:
        a stream containing the BLOB data
        Throws:
        SQLException
      • position

        public long position​(byte[] pattern,
                             long start)
                      throws SQLException
        Deprecated.
        Implements the Blob interface function. Determine the byte position at which the given byte pattern
        Specified by:
        position in interface Blob
        Parameters:
        pattern - is the pattern to search for.
        start - is the position at which to begin searching.
        Returns:
        the position at which the pattern appears, else -1.
        Throws:
        SQLException
      • position

        public long position​(Blob pattern,
                             long start)
                      throws SQLException
        Deprecated.
        Implements the Blob interface function. Determine the byte position at which the given pattern
        Specified by:
        position in interface Blob
        Parameters:
        pattern - is the pattern to search for.
        start - is the position at which to begin searching.
        Returns:
        the position at which the pattern appears, else -1.
        Throws:
        SQLException
      • getBytes

        public int getBytes​(long pos,
                            int length,
                            byte[] buf)
                     throws SQLException
        Deprecated.
        Oracle extension. Copy the contents of the BLOB at the requested position to suppied buffer.
        Specified by:
        getBytes in interface OracleBlob
        Parameters:
        pos - is the first byte of the blob to be extracted.
        length - is the number of consecutive bytes to be copied.
        buf - is the buffer to had the extracted bytes.
        Returns:
        a byte array containing a portion of the BLOB
        Throws:
        SQLException
      • putBytes

        public int putBytes​(long pos,
                            byte[] bytes)
                     throws SQLException
        Deprecated.
        This method is deprecated -- use setBytes
        Oracle extension. Put data to the BLOB at the requested position.
        Specified by:
        putBytes in interface oracle.jdbc.internal.OracleBlob
        Parameters:
        pos - is the position data to be put.
        bytes - is the data to be written into BLOB.
        Returns:
        the number of bytes actually written.
        Throws:
        SQLException
      • putBytes

        public int putBytes​(long pos,
                            byte[] bytes,
                            int length)
                     throws SQLException
        Deprecated.
        This method is deprecated -- use setBytes
        Oracle extension. Put data to the BLOB at the requested position.
        Specified by:
        putBytes in interface oracle.jdbc.internal.OracleBlob
        Parameters:
        pos - is the position data to be put.
        bytes - is the data to be written into BLOB.
        length - is the length of the data to be written into BLOB.
        Returns:
        the number of bytes actually written.
        Throws:
        SQLException
      • getBinaryOutputStream

        public OutputStream getBinaryOutputStream()
                                           throws SQLException
        Deprecated.
        This method is deprecated. Use setBinaryStream(1L).
        Oracle extension. Write to the BLOB from a stream.
        Specified by:
        getBinaryOutputStream in interface oracle.jdbc.internal.OracleBlob
        Returns:
        a output stream to write data to the BLOB
        Throws:
        SQLException
      • getChunkSize

        public int getChunkSize()
                         throws SQLException
        Deprecated.
        Oracle extension. Get database LOB storage chunk size in database.
        Specified by:
        getChunkSize in interface oracle.jdbc.internal.OracleBlob
        Returns:
        size in bytes
        Throws:
        SQLException
      • getBufferSize

        public int getBufferSize()
                          throws SQLException
        Deprecated.
        Oracle extension. Get ideal LOB db access buffer size.
        Specified by:
        getBufferSize in interface oracle.jdbc.internal.OracleBlob
        Returns:
        size in bytes
        Throws:
        SQLException
      • empty_lob

        public static BLOB empty_lob()
                              throws SQLException
        Deprecated.
        use getEmptyBLOB instead
        Return a empty lob. An empty lob is used initialize a LOB column/attribute. Note: an empty lob can not be read or written
        Returns:
        a empty lob
        Throws:
        SQLException
        Since:
        8.1.7
      • getEmptyBLOB

        public static BLOB getEmptyBLOB()
                                 throws SQLException
        Deprecated.
        Return a empty lob. An empty lob is used initialize a BLOB column/attribute. Note: an empty lob can not be read or written
        Returns:
        a empty lob
        Throws:
        SQLException
        Since:
        10.2
      • isEmptyLob

        public boolean isEmptyLob()
                           throws SQLException
        Deprecated.
        Return true if the lob locator points to a empty blob. False if it does not. This method supports only Blobs that are not returned from the database. For Blobs returned from the database, use length(), i.e. check for zero length.
        Specified by:
        isEmptyLob in interface OracleBlob
        Returns:
        true if the lob locator points to a empty blob. False if it does not.
        Throws:
        SQLException
        Since:
        8.1.7
      • isSecureFile

        public boolean isSecureFile()
                             throws SQLException
        Deprecated.
        Returns true if this is a SecureFile (LOBs with the STORE AS SECUREFILE option, which were introduced in Oracle Database 11g Release 1).
        Specified by:
        isSecureFile in interface OracleBlob
        Returns:
        true if this is a SecureFile and false otherwise.
        Throws:
        SQLException
      • getBinaryOutputStream

        public OutputStream getBinaryOutputStream​(long pos)
                                           throws SQLException
        Deprecated.
        This method is deprecated -- use setBinaryStream
        Write to the BLOB from a stream at the requested position.
        Specified by:
        getBinaryOutputStream in interface oracle.jdbc.internal.OracleBlob
        Parameters:
        pos - is the position data to be put.
        Returns:
        a output stream to write data to the BLOB
        Throws:
        SQLException
        Since:
        8.2.0
      • getBinaryStream

        public InputStream getBinaryStream​(long pos)
                                    throws SQLException
        Deprecated.
        Read from the BLOB as a stream at the requested position.
        Specified by:
        getBinaryStream in interface OracleBlob
        Parameters:
        pos - is the position data to be read, should be greater than 0.
        Returns:
        a input stream to read data from the BLOB
        Throws:
        SQLException
        Since:
        8.2.0
      • trim

        public void trim​(long newlen)
                  throws SQLException
        Deprecated.
        This method id deprecated -- use truncate
        Trim the value of the BLOB to the length you specify in the newlen parameter.
        Specified by:
        trim in interface oracle.jdbc.internal.OracleBlob
        Parameters:
        newlen - the new length of the BLOB.
        Throws:
        SQLException
        Since:
        8.2.0
      • createTemporary

        public static BLOB createTemporary​(Connection conn,
                                           boolean cache,
                                           int _duration)
                                    throws SQLException
        Deprecated.
        Create a temporary blob.
        Parameters:
        cache - Specifies if LOB should be read into buffer cache or not.
        _duration - The duration of the temporary LOB. The following are valid values: DURATION_SESSION, DURATION_CALL.
        Returns:
        A temporary blob.
        Throws:
        SQLException
        Since:
        8.2.0
      • freeTemporary

        public static void freeTemporary​(BLOB temp_lob)
                                  throws SQLException
        Deprecated.
        Free the contents and the locator of the temporary blob.
        Parameters:
        temp_lob - A temporary blob to be freeed.
        Throws:
        SQLException - if temp_lob is a permanent lob or temp_lob has already been freed.
        Since:
        8.2.0
      • isTemporary

        public static boolean isTemporary​(BLOB lob)
                                   throws SQLException
        Deprecated.
        Return true if the lob locator points to a temporary blob. False if it does not.
        Parameters:
        lob - the blob to test.
        Returns:
        true if the lob locator points to a temporary blob. False if it does not.
        Throws:
        SQLException
        Since:
        8.2.0
      • getDuration

        public static short getDuration​(BLOB lob)
                                 throws SQLException
        Deprecated.
        return the duration of a temporary LOB
        Returns:
        the duration of a temporary LOB
        Throws:
        SQLException
        Since:
        18.1
      • freeTemporary

        public void freeTemporary()
                           throws SQLException
        Deprecated.
        Free the contents and the locator of the temporary blob.
        Specified by:
        freeTemporary in interface oracle.jdbc.internal.OracleLargeObject
        Throws:
        SQLException - if self is a permanent lob or self has already been freed.
        Since:
        8.2.0
      • isTemporary

        public boolean isTemporary()
                            throws SQLException
        Deprecated.
        Return true if the lob locator points to a temporary blob. False if it does not.
        Specified by:
        isTemporary in interface OracleBlob
        Specified by:
        isTemporary in interface oracle.jdbc.internal.OracleLargeObject
        Returns:
        true if the lob locator points to a temporary blob. False if it does not.
        Throws:
        SQLException
        Since:
        8.2.0
      • getDuration

        public short getDuration()
                          throws SQLException
        Deprecated.
        return the duration of a temporary LOB
        Specified by:
        getDuration in interface oracle.jdbc.internal.OracleLargeObject
        Returns:
        the duration of a temporary LOB
        Throws:
        SQLException
        Since:
        18.1
      • open

        public void open​(int mode)
                  throws SQLException
        Deprecated.
        Open a BLOB in the indicated mode. Valid modes include MODE_READONLY, and MODE_READWRITE. It is an error to open the same LOB twice.
        Throws:
        SQLException
        Since:
        8.2.0
      • isOpen

        public boolean isOpen()
                       throws SQLException
        Deprecated.
        Check whether the BLOB is opened.
        Specified by:
        isOpen in interface OracleBlob
        Returns:
        true if the LOB is opened.
        Throws:
        SQLException
        Since:
        8.2.0
      • setBytes

        public int setBytes​(long pos,
                            byte[] bytes)
                     throws SQLException
        Deprecated.
        JDBC 3.0 Writes the given array of bytes to the BLOB value that this Blob object represents, starting at position pos, and returns the number of bytes written.
        Specified by:
        setBytes in interface Blob
        Parameters:
        pos - the position in the BLOB object at which to start writing
        bytes - the array of bytes to be written to the BLOB value that this Blob object represents
        Returns:
        the number of bytes written
        Throws:
        SQLException - if there is an error accessing the BLOB value
        Since:
        9.0.2
      • setBytes

        public int setBytes​(long pos,
                            byte[] bytes,
                            int offset,
                            int len)
                     throws SQLException
        Deprecated.
        JDBC 3.0 Writes all or part of the given byte array to the BLOB value that this Blob object represents and returns the number of bytes written. Writing starts at position pos in the BLOB value; len bytes from the given byte array are written.
        Specified by:
        setBytes in interface Blob
        Parameters:
        pos - the position in the BLOB object at which to start writing
        bytes - the array of bytes to be written to this BLOB object
        offset - the offset into the array bytes at which to start reading the bytes to be set
        len - the number of bytes to be written to the BLOB value from the array of bytes bytes
        Returns:
        the number of bytes written
        Throws:
        SQLException - if there is an error accessing the BLOB value
        Since:
        9.0.2
      • setBinaryStream

        public OutputStream setBinaryStream​(long pos)
                                     throws SQLException
        Deprecated.
        JDBC 3.0 Retrieves a stream that can be used to write to the BLOB value that this Blob object represents. The stream begins at position pos.
        Specified by:
        setBinaryStream in interface Blob
        Parameters:
        pos - the position in the BLOB value at which to start writing
        Returns:
        a java.io.OutputStream object to which data can be written
        Throws:
        SQLException - if there is an error accessing the BLOB value
        Since:
        9.0.2
        See Also:
        getBinaryStream()
      • truncate

        public void truncate​(long len)
                      throws SQLException
        Deprecated.
        JDBC 3.0 Truncates the BLOB value that this Blob object represents to be len bytes in length.
        Specified by:
        truncate in interface Blob
        Parameters:
        len - the length, in bytes, to which the BLOB value that this Blob object represents should be truncated
        Throws:
        SQLException - if there is an error accessing the BLOB value
        Since:
        9.0.2
      • toJdbc

        public Object toJdbc()
                      throws SQLException
        Deprecated.
        Oracle extension. Convert this data object into its default Java object type.
        Specified by:
        toJdbc in interface oracle.jdbc.internal.OracleBlob
        Specified by:
        toJdbc in interface oracle.jdbc.internal.OracleDatumWithConnection
        Specified by:
        toJdbc in class Datum
        Returns:
        this object.
        Throws:
        SQLException - if any of the lower layer code throws an exception.
      • isConvertibleTo

        public boolean isConvertibleTo​(Class<?> jClass)
        Deprecated.
        Oracle extension. Test whether this data object can be converted to the specified Java data type.
        Specified by:
        isConvertibleTo in interface oracle.jdbc.internal.OracleBlob
        Specified by:
        isConvertibleTo in interface oracle.jdbc.internal.OracleDatumWithConnection
        Specified by:
        isConvertibleTo in class Datum
        Parameters:
        jClass - specifies the Java data type to test against.
        Returns:
        true if this data object is convertible to the specified Java class, and a corresponding xxxValue() method is available; otherwise, a false is returned.
      • getJavaSqlConnection

        public Connection getJavaSqlConnection()
                                        throws SQLException
        Deprecated.
        Description copied from class: DatumWithConnection
        Oracle extension Return the java.sql.Connection associated with the receiver. Since 9.0.0 not all Oracle JDBC connection objects are assignment compatible with oracle.jdbc.driver.OracleConnection. If the connection is wrapped, return the outermost wrapper.
        Specified by:
        getJavaSqlConnection in interface oracle.jdbc.internal.OracleBlob
        Specified by:
        getJavaSqlConnection in interface oracle.jdbc.internal.OracleDatumWithConnection
        Overrides:
        getJavaSqlConnection in class DatumWithConnection
        Returns:
        the connection
        Throws:
        SQLException - if an error occurs
      • getPrefetchedDataSize

        public final int getPrefetchedDataSize()
        Deprecated.
        Specified by:
        getPrefetchedDataSize in interface oracle.jdbc.internal.OracleBlob
      • canReadBasicLobDataInLocator

        public boolean canReadBasicLobDataInLocator()
                                             throws SQLException
        Deprecated.
        Can the lob data be read directly from the locator?
        Specified by:
        canReadBasicLobDataInLocator in interface oracle.jdbc.internal.OracleBlob
        Returns:
        True if we can; false otherwise.
        Throws:
        SQLException
      • free

        public void free()
                  throws SQLException
        Deprecated.
        Free the resources the blob holds.
        Specified by:
        free in interface Blob
        Throws:
        SQLException
        Since:
        11.0
      • getBinaryStream

        public InputStream getBinaryStream​(long pos,
                                           long length)
                                    throws SQLException
        Deprecated.
        Return a binary stream beginning at the specified position and ofthe specified length.
        Specified by:
        getBinaryStream in interface Blob
        Parameters:
        pos - start position
        length - number of bytes in the result
        Throws:
        SQLException - if pos is less than 1 or if pos is greater than the number of bytes in the Blob or if pos + length is greater than the number of bytes in the Blob.
        Since:
        11.0
      • setBytes

        public void setBytes​(byte[] locator)
        Deprecated.
        Description copied from class: Datum
        Sets datum value using a byte array. The byte array is copied.
        Specified by:
        setBytes in interface oracle.jdbc.internal.OracleDatumWithConnection
        Overrides:
        setBytes in class Datum
        Parameters:
        locator - byte array used to set the datum value
      • toSQLXML

        public SQLXML toSQLXML()
                        throws SQLException
        Deprecated.
        Returns an object which impements java.sql.SQLXML with content take from this Clob.
        Specified by:
        toSQLXML in interface OracleBlob
        Returns:
        the new SQLXML object
        Throws:
        SQLException
        Since:
        12.2
      • toSQLXML

        public SQLXML toSQLXML​(int csid)
                        throws SQLException
        Deprecated.
        Returns an object which impements java.sql.SQLXML with content taken from this Blob.
        Specified by:
        toSQLXML in interface OracleBlob
        Returns:
        the new SQLXML object
        Throws:
        SQLException
        Since:
        12.2