Package org.postgresql.jdbc
Class ArrayEncoding.TwoDimensionPrimitiveArrayEncoder<A>
java.lang.Object
org.postgresql.jdbc.ArrayEncoding.TwoDimensionPrimitiveArrayEncoder<A>
- All Implemented Interfaces:
ArrayEncoding.ArrayEncoder<A[]>
- Enclosing class:
ArrayEncoding
private static final class ArrayEncoding.TwoDimensionPrimitiveArrayEncoder<A>
extends Object
implements ArrayEncoding.ArrayEncoder<A[]>
Wraps an
ArrayEncoding.AbstractArrayEncoder implementation and provides optimized
support for 2 dimensions.-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescription -
Method Summary
Modifier and TypeMethodDescriptionvoidappendArray(StringBuilder sb, char delim, A[] array) AppendStringrepresentation of array to sb.intThe default array type oid supported by this instance.booleansupportBinaryRepresentation(int oid) Indicates if an array can be encoded in binary form to array oid.toArrayString(char delim, A[] array) CreatesStringrepresentation of the array.byte[]toBinaryRepresentation(BaseConnection connection, A[] array, int oid) Creates binary representation of the array.
-
Field Details
-
support
-
-
Constructor Details
-
TwoDimensionPrimitiveArrayEncoder
TwoDimensionPrimitiveArrayEncoder(ArrayEncoding.AbstractArrayEncoder<A> support) - Parameters:
support- The instance providing support for the base array type.
-
-
Method Details
-
getDefaultArrayTypeOid
public int getDefaultArrayTypeOid()The default array type oid supported by this instance.- Specified by:
getDefaultArrayTypeOidin interfaceArrayEncoding.ArrayEncoder<A>- Returns:
- The default array type oid supported by this instance.
-
toArrayString
CreatesStringrepresentation of the array.- Specified by:
toArrayStringin interfaceArrayEncoding.ArrayEncoder<A>- Parameters:
delim- The character to use to delimit between elements.array- The array to represent as aString.- Returns:
Stringrepresentation of the array.
-
appendArray
AppendStringrepresentation of array to sb.- Specified by:
appendArrayin interfaceArrayEncoding.ArrayEncoder<A>- Parameters:
sb- TheStringBuilderto append to.delim- The delimiter between elements.array- The array to represent. Will not benull, but may containnullelements.
-
supportBinaryRepresentation
public boolean supportBinaryRepresentation(int oid) Indicates if an array can be encoded in binary form to array oid.- Specified by:
supportBinaryRepresentationin interfaceArrayEncoding.ArrayEncoder<A>- Parameters:
oid- The array oid to see check for binary support.- Returns:
- Indication of whether
ArrayEncoding.ArrayEncoder.toBinaryRepresentation(BaseConnection, Object, int)is supported for oid.
-
toBinaryRepresentation
public byte[] toBinaryRepresentation(BaseConnection connection, A[] array, int oid) throws SQLException, SQLFeatureNotSupportedException Creates binary representation of the array. 4 bytes - dimension 4 bytes - oid 4 bytes - ? 8*d bytes - dimension length- Specified by:
toBinaryRepresentationin interfaceArrayEncoding.ArrayEncoder<A>- Parameters:
connection- The connection the binary representation will be used on. Attributes from the connection might impact how values are translated to binary.array- The array to binary encode. Must not benull, but may containnullelements.oid- The array type oid to use. Calls toArrayEncoding.ArrayEncoder.supportBinaryRepresentation(int)must have returnedtrue.- Returns:
- The binary representation of array.
- Throws:
SQLFeatureNotSupportedException- IfArrayEncoding.ArrayEncoder.supportBinaryRepresentation(int)is false for oid.SQLException
-