Interface CopyIn

All Superinterfaces:
CopyOperation
All Known Subinterfaces:
CopyDual
All Known Implementing Classes:
CopyDualImpl, CopyInImpl, PGCopyOutputStream

public interface CopyIn extends CopyOperation
Copy bulk data from client into a PostgreSQL table very fast.
  • Method Details

    • writeToCopy

      void writeToCopy(byte[] buf, int off, int siz) throws SQLException
      Writes specified part of given byte array to an open and writable copy operation.
      Parameters:
      buf - array of bytes to write
      off - offset of first byte to write (normally zero)
      siz - number of bytes to write (normally buf.length)
      Throws:
      SQLException - if the operation fails
    • writeToCopy

      void writeToCopy(ByteStreamWriter from) throws SQLException
      Writes a ByteStreamWriter to an open and writable copy operation.
      Parameters:
      from - the source of bytes, e.g. a ByteBufferByteStreamWriter
      Throws:
      SQLException - if the operation fails
    • flushCopy

      void flushCopy() throws SQLException
      Force any buffered output to be sent over the network to the backend. In general this is a useless operation as it will get pushed over in due time or when endCopy is called. Some specific modified server versions (Truviso) want this data sooner. If you are unsure if you need to use this method, don't.
      Throws:
      SQLException - if the operation fails.
    • endCopy

      long endCopy() throws SQLException
      Finishes copy operation successfully.
      Returns:
      number of updated rows for server 8.2 or newer (see getHandledRowCount())
      Throws:
      SQLException - if the operation fails.