Class

io.smartdatalake.util.evolution

UnsafeUnaryUdfExpression

Related Doc: package evolution

Permalink

case class UnsafeUnaryUdfExpression(child: Expression, udf: (Any) ⇒ Any, tgtDataType: DataType) extends UnaryExpression with Product with Serializable

With Spark 3.0 the API for Udf's was made more typesafe. It's no longer possible to create a Udf and give it's return type as StructType. This implements an explicitly unsafe unary udf, which takes a function with signature Any -> Any as transformation. UnsafeUnaryUdfExpression is the Udf expression that is embedded and executed in Spark logical plan. Use UnsafeUnaryUdf to create the udf function to be used in Spark DataFrame API.

Linear Supertypes
Serializable, Serializable, UnaryExpression, Expression, TreeNode[Expression], Product, Equals, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. UnsafeUnaryUdfExpression
  2. Serializable
  3. Serializable
  4. UnaryExpression
  5. Expression
  6. TreeNode
  7. Product
  8. Equals
  9. AnyRef
  10. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new UnsafeUnaryUdfExpression(child: Expression, udf: (Any) ⇒ Any, tgtDataType: DataType)

    Permalink

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. def apply(number: Int): TreeNode[_]

    Permalink
    Definition Classes
    TreeNode
  5. def argString: String

    Permalink
    Definition Classes
    TreeNode
  6. def asCode: String

    Permalink
    Definition Classes
    TreeNode
  7. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  8. lazy val canonicalized: Expression

    Permalink
    Definition Classes
    Expression
  9. def checkInputDataTypes(): TypeCheckResult

    Permalink
    Definition Classes
    Expression
  10. val child: Expression

    Permalink
    Definition Classes
    UnsafeUnaryUdfExpression → UnaryExpression
  11. final def children: Seq[Expression]

    Permalink
    Definition Classes
    UnaryExpression → TreeNode
  12. def childrenResolved: Boolean

    Permalink
    Definition Classes
    Expression
  13. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  14. def collect[B](pf: PartialFunction[Expression, B]): Seq[B]

    Permalink
    Definition Classes
    TreeNode
  15. def collectFirst[B](pf: PartialFunction[Expression, B]): Option[B]

    Permalink
    Definition Classes
    TreeNode
  16. def collectLeaves(): Seq[Expression]

    Permalink
    Definition Classes
    TreeNode
  17. lazy val containsChild: Set[TreeNode[_]]

    Permalink
    Definition Classes
    TreeNode
  18. def dataType: DataType

    Permalink
    Definition Classes
    UnsafeUnaryUdfExpression → Expression
  19. def defineCodeGen(ctx: CodegenContext, ev: ExprCode, f: (String) ⇒ String): ExprCode

    Permalink
    Attributes
    protected
    Definition Classes
    UnaryExpression
  20. lazy val deterministic: Boolean

    Permalink
    Definition Classes
    Expression
  21. def doGenCode(ctx: CodegenContext, ev: ExprCode): ExprCode

    Permalink
    Attributes
    protected
    Definition Classes
    UnsafeUnaryUdfExpression → Expression
  22. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  23. def eval(input: InternalRow): Any

    Permalink
    Definition Classes
    UnaryExpression → Expression
  24. def fastEquals(other: TreeNode[_]): Boolean

    Permalink
    Definition Classes
    TreeNode
  25. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  26. def find(f: (Expression) ⇒ Boolean): Option[Expression]

    Permalink
    Definition Classes
    TreeNode
  27. def flatArguments: Iterator[Any]

    Permalink
    Attributes
    protected
    Definition Classes
    Expression
  28. def flatMap[A](f: (Expression) ⇒ TraversableOnce[A]): Seq[A]

    Permalink
    Definition Classes
    TreeNode
  29. def foldable: Boolean

    Permalink
    Definition Classes
    UnaryExpression → Expression
  30. def foreach(f: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    TreeNode
  31. def foreachUp(f: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    TreeNode
  32. def genCode(ctx: CodegenContext): ExprCode

    Permalink
    Definition Classes
    Expression
  33. def generateTreeString(depth: Int, lastChildren: Seq[Boolean], builder: StringBuilder, verbose: Boolean, prefix: String, addSuffix: Boolean): StringBuilder

    Permalink
    Definition Classes
    TreeNode
  34. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  35. def hashCode(): Int

    Permalink
    Definition Classes
    TreeNode → AnyRef → Any
  36. def innerChildren: Seq[TreeNode[_]]

    Permalink
    Attributes
    protected
    Definition Classes
    TreeNode
  37. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  38. def jsonFields: List[JField]

    Permalink
    Attributes
    protected
    Definition Classes
    TreeNode
  39. def makeCopy(newArgs: Array[AnyRef]): Expression

    Permalink
    Definition Classes
    TreeNode
  40. def map[A](f: (Expression) ⇒ A): Seq[A]

    Permalink
    Definition Classes
    TreeNode
  41. def mapChildren(f: (Expression) ⇒ Expression): Expression

    Permalink
    Definition Classes
    TreeNode
  42. def mapProductIterator[B](f: (Any) ⇒ B)(implicit arg0: ClassTag[B]): Array[B]

    Permalink
    Attributes
    protected
    Definition Classes
    TreeNode
  43. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  44. def nodeName: String

    Permalink
    Definition Classes
    TreeNode
  45. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  46. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  47. def nullSafeCodeGen(ctx: CodegenContext, ev: ExprCode, f: (String) ⇒ String): ExprCode

    Permalink
    Attributes
    protected
    Definition Classes
    UnaryExpression
  48. def nullSafeEval(input: Any): Any

    Permalink
    Definition Classes
    UnsafeUnaryUdfExpression → UnaryExpression
  49. def nullable: Boolean

    Permalink
    Definition Classes
    UnsafeUnaryUdfExpression → UnaryExpression → Expression
  50. def numberedTreeString: String

    Permalink
    Definition Classes
    TreeNode
  51. val origin: Origin

    Permalink
    Definition Classes
    TreeNode
  52. def otherCopyArgs: Seq[AnyRef]

    Permalink
    Attributes
    protected
    Definition Classes
    TreeNode
  53. def p(number: Int): Expression

    Permalink
    Definition Classes
    TreeNode
  54. def prettyJson: String

    Permalink
    Definition Classes
    TreeNode
  55. def prettyName: String

    Permalink
    Definition Classes
    UnsafeUnaryUdfExpression → Expression
  56. def references: AttributeSet

    Permalink
    Definition Classes
    Expression
  57. lazy val resolved: Boolean

    Permalink
    Definition Classes
    Expression
  58. def semanticEquals(other: Expression): Boolean

    Permalink
    Definition Classes
    Expression
  59. def semanticHash(): Int

    Permalink
    Definition Classes
    Expression
  60. def simpleString: String

    Permalink
    Definition Classes
    Expression → TreeNode
  61. def sql: String

    Permalink
    Definition Classes
    Expression
  62. def stringArgs: Iterator[Any]

    Permalink
    Attributes
    protected
    Definition Classes
    TreeNode
  63. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  64. val tgtDataType: DataType

    Permalink
  65. def toJSON: String

    Permalink
    Definition Classes
    TreeNode
  66. def toString(): String

    Permalink
    Definition Classes
    Expression → TreeNode → AnyRef → Any
  67. def transform(rule: PartialFunction[Expression, Expression]): Expression

    Permalink
    Definition Classes
    TreeNode
  68. def transformDown(rule: PartialFunction[Expression, Expression]): Expression

    Permalink
    Definition Classes
    TreeNode
  69. def transformUp(rule: PartialFunction[Expression, Expression]): Expression

    Permalink
    Definition Classes
    TreeNode
  70. def treeString(verbose: Boolean, addSuffix: Boolean): String

    Permalink
    Definition Classes
    TreeNode
  71. def treeString: String

    Permalink
    Definition Classes
    TreeNode
  72. val udf: (Any) ⇒ Any

    Permalink
  73. final def verboseString: String

    Permalink
    Definition Classes
    Expression → TreeNode
  74. def verboseStringWithSuffix: String

    Permalink
    Definition Classes
    TreeNode
  75. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  76. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  77. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  78. def withNewChildren(newChildren: Seq[Expression]): Expression

    Permalink
    Definition Classes
    TreeNode

Inherited from Serializable

Inherited from Serializable

Inherited from UnaryExpression

Inherited from Expression

Inherited from TreeNode[Expression]

Inherited from Product

Inherited from Equals

Inherited from AnyRef

Inherited from Any

Ungrouped