idea运行报错问题汇总

1java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.String

运行代码

          customerDF.rdd.map(row => {
      val a = row.getAs[String]("f_key")
      println(a)
    }).foreach(println)

报错

java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.String
	at com.hg.mrtetl.hbasetest.test.HfileBbase$$anonfun$main$2.apply(HfileBbase.scala:47)
	at com.hg.mrtetl.hbasetest.test.HfileBbase$$anonfun$main$2.apply(HfileBbase.scala:46)
	at scala.collection.Iterator$$anon$11.next(Iterator.scala:409)
	at scala.collection.Iterator$class.foreach(Iterator.scala:893)

sparksql调用getAs方法,要求查询到数据类型跟它的泛型一致因此,通过判断是类型转换异常,查出来的类型是Long类型,结果我们需要的是String类型,进行更改类型操作

    customerDF.rdd.map(row => {
      val a = row.getAs[Long]("f_key")
      println(a)
    }).foreach(println)
    
    
    //执行不在报错

思考:如何遍历循多列,而且列的类型不一样

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值