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)
//执行不在报错
思考:如何遍历循多列,而且列的类型不一样