Kau*_*hal 5 apache-spark apache-spark-sql
Column如果仅使用Literal(没有数据框列),有什么方法可以评估我的表达式。
例如,类似:
val result: Int = someFunction(lit(3) * lit(5))
//result: Int = 15
Run Code Online (Sandbox Code Playgroud)
要么
import org.apache.spark.sql.function.sha1
val result: String = someFunction(sha1(lit("5")))
//result: String = ac3478d69a3c81fa62e60f5c3696165a4e5e6ac4
Run Code Online (Sandbox Code Playgroud)
我可以使用数据框进行评估
val result = Seq(1).toDF.select(sha1(lit("5"))).as[String].first
//result: String = ac3478d69a3c81fa62e60f5c3696165a4e5e6ac4
Run Code Online (Sandbox Code Playgroud)
但是,有什么方法可以在不使用数据框的情况下获得相同的结果?
要评估文字列,您可以将其转换为,Expression而eval无需提供input行:
scala> sha1(lit("1").cast("binary")).expr.eval()
res1: Any = 356a192b7913b04c54574d18c28d46e6395428ab
Run Code Online (Sandbox Code Playgroud)
只要该函数为,UserDefinedFunction它将以相同的方式工作:
scala> val f = udf((x: Int) => x)
f: org.apache.spark.sql.expressions.UserDefinedFunction = UserDefinedFunction(<function1>,IntegerType,Some(List(IntegerType)))
scala> f(lit(3) * lit(5)).expr.eval()
res3: Any = 15
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2104 次 |
| 最近记录: |