Package org.postgresql.copy
Class PGCopyOutputStream
java.lang.Object
java.io.OutputStream
org.postgresql.copy.PGCopyOutputStream
- All Implemented Interfaces:
Closeable
,Flushable
,AutoCloseable
,CopyIn
,CopyOperation
OutputStream for buffered input into a PostgreSQL COPY FROM STDIN operation.
-
Constructor Summary
ConstructorDescriptionUse given CopyIn operation for writing.PGCopyOutputStream
(CopyIn op, int bufferSize) Use given CopyIn operation for writing.PGCopyOutputStream
(PGConnection connection, String sql) Uses given connection for specified COPY FROM STDIN operation.PGCopyOutputStream
(PGConnection connection, String sql, int bufferSize) Uses given connection for specified COPY FROM STDIN operation. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Cancels this copy operation, discarding any exchanged data.void
close()
long
endCopy()
Finishes copy operation successfully.void
flush()
void
Force any buffered output to be sent over the network to the backend.int
int
getFieldFormat
(int field) int
long
After successful end of copy, returns the number of database records handled in that operation.boolean
isActive()
void
write
(byte[] buf) void
write
(byte[] buf, int off, int siz) void
write
(int b) void
writeToCopy
(byte[] buf, int off, int siz) Writes specified part of given byte array to an open and writable copy operation.void
writeToCopy
(ByteStreamWriter from) Writes a ByteStreamWriter to an open and writable copy operation.Methods inherited from class java.io.OutputStream
nullOutputStream
-
Constructor Details
-
PGCopyOutputStream
Uses given connection for specified COPY FROM STDIN operation.- Parameters:
connection
- database connection to use for copying (protocol version 3 required)sql
- COPY FROM STDIN statement- Throws:
SQLException
- if initializing the operation fails
-
PGCopyOutputStream
Uses given connection for specified COPY FROM STDIN operation.- Parameters:
connection
- database connection to use for copying (protocol version 3 required)sql
- COPY FROM STDIN statementbufferSize
- try to send this many bytes at a time- Throws:
SQLException
- if initializing the operation fails
-
PGCopyOutputStream
Use given CopyIn operation for writing.- Parameters:
op
- COPY FROM STDIN operation
-
PGCopyOutputStream
Use given CopyIn operation for writing.- Parameters:
op
- COPY FROM STDIN operationbufferSize
- try to send this many bytes at a time
-
-
Method Details
-
write
- Specified by:
write
in classOutputStream
- Throws:
IOException
-
write
- Overrides:
write
in classOutputStream
- Throws:
IOException
-
write
- Overrides:
write
in classOutputStream
- Throws:
IOException
-
close
- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
- Overrides:
close
in classOutputStream
- Throws:
IOException
-
flush
- Specified by:
flush
in interfaceFlushable
- Overrides:
flush
in classOutputStream
- Throws:
IOException
-
writeToCopy
Description copied from interface:CopyIn
Writes specified part of given byte array to an open and writable copy operation.- Specified by:
writeToCopy
in interfaceCopyIn
- Parameters:
buf
- array of bytes to writeoff
- offset of first byte to write (normally zero)siz
- number of bytes to write (normally buf.length)- Throws:
SQLException
- if the operation fails
-
writeToCopy
Description copied from interface:CopyIn
Writes a ByteStreamWriter to an open and writable copy operation.- Specified by:
writeToCopy
in interfaceCopyIn
- Parameters:
from
- the source of bytes, e.g. a ByteBufferByteStreamWriter- Throws:
SQLException
- if the operation fails
-
getFormat
public int getFormat()- Specified by:
getFormat
in interfaceCopyOperation
- Returns:
- overall format of each row: 0 = textual, 1 = binary
-
getFieldFormat
public int getFieldFormat(int field) - Specified by:
getFieldFormat
in interfaceCopyOperation
- Parameters:
field
- number of field (0..fieldCount()-1)- Returns:
- format of requested field: 0 = textual, 1 = binary
-
cancelCopy
Description copied from interface:CopyOperation
Cancels this copy operation, discarding any exchanged data.- Specified by:
cancelCopy
in interfaceCopyOperation
- Throws:
SQLException
- if cancelling fails
-
getFieldCount
public int getFieldCount()- Specified by:
getFieldCount
in interfaceCopyOperation
- Returns:
- number of fields in each row for this operation
-
isActive
public boolean isActive()- Specified by:
isActive
in interfaceCopyOperation
- Returns:
- is connection reserved for this Copy operation?
-
flushCopy
Description copied from interface:CopyIn
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.- Specified by:
flushCopy
in interfaceCopyIn
- Throws:
SQLException
- if the operation fails.
-
endCopy
Description copied from interface:CopyIn
Finishes copy operation successfully.- Specified by:
endCopy
in interfaceCopyIn
- Returns:
- number of updated rows for server 8.2 or newer (see getHandledRowCount())
- Throws:
SQLException
- if the operation fails.
-
getHandledRowCount
public long getHandledRowCount()Description copied from interface:CopyOperation
After successful end of copy, returns the number of database records handled in that operation. Only implemented in PostgreSQL server version 8.2 and up. Otherwise, returns -1.- Specified by:
getHandledRowCount
in interfaceCopyOperation
- Returns:
- number of handled rows or -1
-