Package com.clickhouse.client.data
Class ClickHouseArrayValue<T>
- java.lang.Object
-
- com.clickhouse.client.data.ClickHouseObjectValue<T[]>
-
- com.clickhouse.client.data.ClickHouseArrayValue<T>
-
- All Implemented Interfaces:
ClickHouseValue,Serializable
public class ClickHouseArrayValue<T> extends ClickHouseObjectValue<T[]>
Wrapper class of Array.- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedClickHouseArrayValue(T[] value)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Object[]asArray()Gets value as an object array.<E> E[]asArray(Class<E> clazz)Gets value as an array.<K,V>
Map<K,V>asMap(Class<K> keyClass, Class<V> valueClass)Gets value as a map.StringasString(int length, Charset charset)Gets value as fixed length(in bytes) string.ClickHouseArrayValue<T>copy(boolean deep)Gets a copy of this value object.booleanequals(Object obj)inthashCode()booleanisNullOrEmpty()Checks if the value is null, or empty for non-null types like Array, Tuple and Map.static <T> ClickHouseArrayValue<T>of(ClickHouseValue ref, T[] value)Update value of the given object or create a new instance ifrefis null.static <T> ClickHouseArrayValue<T>of(T[] value)Wrap the given value.static <T> ClickHouseArrayValue<T>ofEmpty()Creates an empty array.ClickHouseArrayValue<T>resetToNullOrEmpty()Resets value to null, or empty when null is not supported(e.g.protected ClickHouseArrayValue<T>set(T[] value)StringtoSqlExpression()Converts the value to escaped SQL expression.ClickHouseArrayValue<T>update(boolean[] value)Updates value.ClickHouseArrayValue<T>update(byte value)Updates value.ClickHouseArrayValue<T>update(byte[] value)Updates value.ClickHouseArrayValue<T>update(char[] value)Updates value.ClickHouseArrayValue<T>update(double value)Updates value.ClickHouseArrayValue<T>update(double[] value)Updates value.ClickHouseArrayValue<T>update(float value)Updates value.ClickHouseArrayValue<T>update(float[] value)Updates value.ClickHouseArrayValue<T>update(int value)Updates value.ClickHouseArrayValue<T>update(int[] value)Updates value.ClickHouseArrayValue<T>update(long value)Updates value.ClickHouseArrayValue<T>update(long[] value)Updates value.ClickHouseArrayValue<T>update(short value)Updates value.ClickHouseArrayValue<T>update(short[] value)Updates value.ClickHouseArrayValue<T>update(ClickHouseValue value)Updates value.ClickHouseArrayValue<T>update(Enum<?> value)Updates value.ClickHouseArrayValue<T>update(Object value)Updates value.ClickHouseArrayValue<T>update(Object[] value)Updates value.ClickHouseArrayValue<T>update(String value)Updates value.ClickHouseArrayValue<T>update(BigDecimal value)Updates value.ClickHouseArrayValue<T>update(BigInteger value)Updates value.ClickHouseArrayValue<T>update(Inet4Address value)Updates value.ClickHouseArrayValue<T>update(Inet6Address value)Updates value.ClickHouseArrayValue<T>update(LocalDate value)Updates value.ClickHouseArrayValue<T>update(LocalDateTime value)Updates value.ClickHouseArrayValue<T>update(LocalTime value)Updates value.ClickHouseArrayValue<T>update(Collection<?> value)Updates value.ClickHouseArrayValue<T>update(Enumeration<?> value)Updates value.ClickHouseArrayValue<T>update(Map<?,?> value)Updates value.ClickHouseArrayValue<T>update(UUID value)Updates value.ClickHouseValueupdateUnknown(Object value)Updates value when the type is not supported.-
Methods inherited from class com.clickhouse.client.data.ClickHouseObjectValue
asBigDecimal, asBigInteger, asByte, asDouble, asFloat, asInteger, asLong, asObject, asShort, getValue, toString
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface com.clickhouse.client.ClickHouseValue
asBigDecimal, asBoolean, asByteStream, asCharacter, asCharacterStream, asDate, asDateTime, asDateTime, asEnum, asInet4Address, asInet6Address, asInstant, asInstant, asMap, asObject, asOffsetDateTime, asOffsetDateTime, asString, asString, asString, asTime, asTime, asTuple, asUuid, asZonedDateTime, asZonedDateTime, copy, isInfinity, isNaN, newUnsupportedException, update, update, update, update, update, update, update
-
-
-
-
Constructor Detail
-
ClickHouseArrayValue
protected ClickHouseArrayValue(T[] value)
-
-
Method Detail
-
ofEmpty
public static <T> ClickHouseArrayValue<T> ofEmpty()
Creates an empty array.- Type Parameters:
T- type of the array- Returns:
- empty array
-
of
public static <T> ClickHouseArrayValue<T> of(T[] value)
Wrap the given value.- Type Parameters:
T- type of element- Parameters:
value- value- Returns:
- object representing the value
-
of
public static <T> ClickHouseArrayValue<T> of(ClickHouseValue ref, T[] value)
Update value of the given object or create a new instance ifrefis null.- Type Parameters:
T- type of element- Parameters:
ref- object to update, could be nullvalue- value- Returns:
- same object as
refor a new instance if it's null
-
set
protected ClickHouseArrayValue<T> set(T[] value)
- Overrides:
setin classClickHouseObjectValue<T[]>
-
asArray
public Object[] asArray()
Description copied from interface:ClickHouseValueGets value as an object array.- Returns:
- non-null object array
-
asArray
public <E> E[] asArray(Class<E> clazz)
Description copied from interface:ClickHouseValueGets value as an array.- Type Parameters:
E- type of the element- Parameters:
clazz- class of the element- Returns:
- non-null array
-
asMap
public <K,V> Map<K,V> asMap(Class<K> keyClass, Class<V> valueClass)
Description copied from interface:ClickHouseValueGets value as a map.- Type Parameters:
K- type of keyV- type of value- Parameters:
keyClass- non-null class of keyvalueClass- non-null class of value- Returns:
- non-null map value
-
asString
public String asString(int length, Charset charset)
Description copied from interface:ClickHouseValueGets value as fixed length(in bytes) string.- Specified by:
asStringin interfaceClickHouseValue- Overrides:
asStringin classClickHouseObjectValue<T[]>- Parameters:
length- byte length of the string, 0 or negative number means unboundedcharset- charset, null is same as default(UTF-8)- Returns:
- string value, could be null
-
copy
public ClickHouseArrayValue<T> copy(boolean deep)
Description copied from interface:ClickHouseValueGets a copy of this value object.- Parameters:
deep- true to create a deep copy; false for a shallow copy- Returns:
- copy of this value object
-
isNullOrEmpty
public boolean isNullOrEmpty()
Description copied from interface:ClickHouseValueChecks if the value is null, or empty for non-null types like Array, Tuple and Map.Please pay attention that only nullability will be considered for String, meaning this method will return
falsefor an empty string. This is because String is treated as value-based type instead of a container like Array.- Specified by:
isNullOrEmptyin interfaceClickHouseValue- Overrides:
isNullOrEmptyin classClickHouseObjectValue<T[]>- Returns:
- true if the value is null or empty; false otherwise
-
resetToNullOrEmpty
public ClickHouseArrayValue<T> resetToNullOrEmpty()
Description copied from interface:ClickHouseValueResets value to null, or empty when null is not supported(e.g. Array, Tuple and Map etc.).Keep in mind that String is value-based type, so this method will change its value to null instead of an empty string.
- Specified by:
resetToNullOrEmptyin interfaceClickHouseValue- Overrides:
resetToNullOrEmptyin classClickHouseObjectValue<T[]>- Returns:
- this object
-
toSqlExpression
public String toSqlExpression()
Description copied from interface:ClickHouseValueConverts the value to escaped SQL expression. For example, number 123 will be converted to123, while string "12'3" will be converted to @{code '12\'3'}.- Specified by:
toSqlExpressionin interfaceClickHouseValue- Overrides:
toSqlExpressionin classClickHouseObjectValue<T[]>- Returns:
- escaped SQL expression
-
update
public ClickHouseArrayValue<T> update(boolean[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(char[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(byte value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(byte[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(short value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(short[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(int value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(int[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(long value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(long[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(float value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(float[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(double value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(double[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(BigInteger value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(BigDecimal value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Enum<?> value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Inet4Address value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Inet6Address value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(LocalDate value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(LocalTime value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(LocalDateTime value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Collection<?> value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Enumeration<?> value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Map<?,?> value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(String value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(UUID value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(ClickHouseValue value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Object[] value)
Description copied from interface:ClickHouseValueUpdates value.- Parameters:
value- value to update- Returns:
- this object
-
updateUnknown
public ClickHouseValue updateUnknown(Object value)
Description copied from interface:ClickHouseValueUpdates value when the type is not supported. This method will be called at the end ofClickHouseValue.update(Object)after trying all known classes. By default, it's same asupdate(String.valueOf(value)).Please avoid to call
ClickHouseValue.update(Object)here as it will create endless loop.- Parameters:
value- value to update- Returns:
- this object
-
update
public ClickHouseArrayValue<T> update(Object value)
Description copied from interface:ClickHouseValueUpdates value. This method tries to identify type ofvalueand then use corresponding update method to proceed. Unknown value will be passed toClickHouseValue.updateUnknown(Object).- Specified by:
updatein interfaceClickHouseValue- Overrides:
updatein classClickHouseObjectValue<T[]>- Parameters:
value- value to update, could be null- Returns:
- this object
-
equals
public boolean equals(Object obj)
- Overrides:
equalsin classClickHouseObjectValue<T[]>
-
hashCode
public int hashCode()
- Overrides:
hashCodein classClickHouseObjectValue<T[]>
-
-