自定义函数utf函数(1对1函数)
package SparkSQL.fun.registerfum import org.apache.spark.SparkConf import org.apache.spark.sql.{Dataset, SparkSession} import scala.beans.BeanProperty case class student(@BeanProperty var name: String, @BeanProperty var clz: String, @BeanProperty var age: Int, @BeanProperty var sex: String) object registerfun1 { def main(args: Array[String]): Unit = { val conf = new SparkConf().setAppName("func1").setMaster("local[*]") val session = SparkSession.builder().config(conf).getOrCreate() import session.implicits._ val dataset: Dataset[student] = session.createDataset(Array( student("zs", "c001", 21, "男"), student("ls", "c001", 22, "女"), student("ww", "c001", 23, "男"), student("ml", "c002", 20, "女"), student("zb", "c002", 23, "男") )) // 将每个age字段 +1 session.udf.register("age_auto", (age: Int, num: Int) => { age + num }) dataset.createTempView("student") val frame = session.sql("select name, age_auto(age, 5), sex, clz from student") frame.show() session.stop() } }
本文来自博客园,作者:jsqup,转载请注明原文链接:https://www.cnblogs.com/jsqup/p/16659618.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?