public class EncoderHelpers
extends java.lang.Object
Encoders utility class.| Modifier and Type | Class and Description | 
|---|---|
static class  | 
EncoderHelpers.Utils
Encoder / expression utils that are called from generated code. 
 | 
| Constructor and Description | 
|---|
EncoderHelpers()  | 
| Modifier and Type | Method and Description | 
|---|---|
static <T> org.apache.spark.sql.Encoder<java.util.Collection<T>> | 
collectionEncoder(org.apache.spark.sql.Encoder<T> enc)
Creates a Spark  
Encoder of ArrayType for Java Collections with nullable
 elements. | 
static <T> org.apache.spark.sql.Encoder<java.util.Collection<T>> | 
collectionEncoder(org.apache.spark.sql.Encoder<T> enc,
                 boolean nullable)
Creates a Spark  
Encoder of ArrayType for Java Collections. | 
static <T> org.apache.spark.sql.catalyst.expressions.Expression | 
deserializeOneOf(org.apache.spark.sql.catalyst.expressions.Expression in,
                java.util.List<org.apache.spark.sql.Encoder<T>> encoders)  | 
static <T> org.apache.spark.sql.Encoder<T> | 
encoderFor(Coder<T> coder)
 | 
static <T> org.apache.spark.sql.Encoder<T> | 
encoderOf(java.lang.Class<? super T> cls)
Gets or creates a default  
Encoder for T. | 
static <K,V> org.apache.spark.sql.Encoder<KV<K,V>> | 
kvEncoder(org.apache.spark.sql.Encoder<K> key,
         org.apache.spark.sql.Encoder<V> value)
 | 
static <MapT extends java.util.Map<K,V>,K,V> | 
mapEncoder(org.apache.spark.sql.Encoder<K> key,
          org.apache.spark.sql.Encoder<V> value,
          java.lang.Class<MapT> cls)
Creates a Spark  
Encoder of MapType that deserializes to MapT. | 
static <T1,T2> org.apache.spark.sql.Encoder<org.apache.spark.util.MutablePair<T1,T2>> | 
mutablePairEncoder(org.apache.spark.sql.Encoder<T1> enc1,
                  org.apache.spark.sql.Encoder<T2> enc2)
Creates a Spark  
Encoder for Spark's MutablePair of StructType with
 fields `_1` and `_2`. | 
static <T> org.apache.spark.sql.Encoder<scala.Tuple2<java.lang.Integer,T>> | 
oneOfEncoder(java.util.List<org.apache.spark.sql.Encoder<T>> encoders)
Creates a one-of Spark  
Encoder of StructType where each alternative is
 represented as colum / field named by its index with a separate Encoder each. | 
static <T> org.apache.spark.sql.catalyst.expressions.Expression | 
serializeOneOf(org.apache.spark.sql.catalyst.expressions.Expression in,
              java.util.List<org.apache.spark.sql.Encoder<T>> encoders)  | 
static <T,W extends BoundedWindow> | 
windowedValueEncoder(org.apache.spark.sql.Encoder<T> value,
                    org.apache.spark.sql.Encoder<W> window)
Creates a Spark  
Encoder for T of StructType with fields value,
 timestamp, windows and pane. | 
public static <T> org.apache.spark.sql.Encoder<T> encoderOf(java.lang.Class<? super T> cls)
Encoder for T.public static <T> org.apache.spark.sql.Encoder<T> encoderFor(Coder<T> coder)
Encoder for T of BinaryType
 delegating to a Beam Coder underneath.
 Note: For common types, if available, default Spark Encoders are used instead.
coder - Beam Coderpublic static <T,W extends BoundedWindow> org.apache.spark.sql.Encoder<WindowedValue<T>> windowedValueEncoder(org.apache.spark.sql.Encoder<T> value, org.apache.spark.sql.Encoder<W> window)
Encoder for T of StructType with fields value,
 timestamp, windows and pane.value - Encoder to encode field `value`.window - Encoder to encode individual windows in field `windows`public static <T> org.apache.spark.sql.Encoder<scala.Tuple2<java.lang.Integer,T>> oneOfEncoder(java.util.List<org.apache.spark.sql.Encoder<T>> encoders)
Encoder of StructType where each alternative is
 represented as colum / field named by its index with a separate Encoder each.
 Externally this is represented as tuple (index, data) where an index corresponds to
 an Encoder in the provided list.
encoders - Encoders for each alternative.public static <K,V> org.apache.spark.sql.Encoder<KV<K,V>> kvEncoder(org.apache.spark.sql.Encoder<K> key, org.apache.spark.sql.Encoder<V> value)
key - Encoder to encode field `key`.value - Encoder to encode field `value`public static <T> org.apache.spark.sql.Encoder<java.util.Collection<T>> collectionEncoder(org.apache.spark.sql.Encoder<T> enc)
Encoder of ArrayType for Java Collections with nullable
 elements.enc - Encoder to encode collection elementspublic static <T> org.apache.spark.sql.Encoder<java.util.Collection<T>> collectionEncoder(org.apache.spark.sql.Encoder<T> enc,
                                                                                          boolean nullable)
Encoder of ArrayType for Java Collections.enc - Encoder to encode collection elementsnullable - Allow nullable collection elementspublic static <MapT extends java.util.Map<K,V>,K,V> org.apache.spark.sql.Encoder<MapT> mapEncoder(org.apache.spark.sql.Encoder<K> key,
                                                                                                  org.apache.spark.sql.Encoder<V> value,
                                                                                                  java.lang.Class<MapT> cls)
Encoder of MapType that deserializes to MapT.key - Encoder to encode keysvalue - Encoder to encode valuescls - Specific class to use, supported are HashMap and TreeMappublic static <T1,T2> org.apache.spark.sql.Encoder<org.apache.spark.util.MutablePair<T1,T2>> mutablePairEncoder(org.apache.spark.sql.Encoder<T1> enc1,
                                                                                                                org.apache.spark.sql.Encoder<T2> enc2)
Encoder for Spark's MutablePair of StructType with
 fields `_1` and `_2`.
 This is intended to be used in places such as aggregators.
enc1 - Encoder to encode `_1`enc2 - Encoder to encode `_2`public static <T> org.apache.spark.sql.catalyst.expressions.Expression serializeOneOf(org.apache.spark.sql.catalyst.expressions.Expression in,
                                                                                      java.util.List<org.apache.spark.sql.Encoder<T>> encoders)
public static <T> org.apache.spark.sql.catalyst.expressions.Expression deserializeOneOf(org.apache.spark.sql.catalyst.expressions.Expression in,
                                                                                        java.util.List<org.apache.spark.sql.Encoder<T>> encoders)