首页 > 其他 > 详细

spark 类对象去重

时间:2021-04-20 23:22:11      阅读:33      评论:0      收藏:0      [点我收藏+]
case class User(age:Int, name:String){
override def hashCode(): Int = this.age

override def equals(obj: Any): Boolean = obj match {
  case User(age,_) => this.age == age
  case _ => false
}

}

//Uer 对象重写 hashCode 和equals 方法 判断对象是否相等

sc.parallelize(List(User(11,"op"),User(12,"pp"),User(11,"lp")))
.distinct()
.foreach(println)

结果显示
技术分享图片

或者

sc.parallelize(List(User(11,"op"),User(12,"pp"),User(11,"lp")))
.map((x,null))
.reduceByKey((x,)=>x)
.map(
._1)
.foreach(println)

spark 类对象去重

原文:https://blog.51cto.com/u_15084467/2720506

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!