Error during generated code invocation: com.intellij.debugger.engine.evaluation.EvaluateException: ...

场景描述:

  再从该数据库中读取数据进行处理的时候,需要将某个字段加入到一个动态的map中,然后需要对该map进行filter过滤,在执行过滤方法的时候报错

Error during generated code invocation:
 com.intellij.debugger.engine.evaluation.EvaluateException: Method threw 'java.lang.IllegalAccessError' exception.

  报错截图:

  

  也就是说该map执行不了这个方法。

code:

      val maps = Collection.muttable.Map[String, Int]()
      for (elem <- referenceData.collect()) {
        maps.put(String.valueOf(elem.getAs[Timestamp]("datatime")), elem.getAs[Int]("innum"))
      }
      val exceptMsgs = auditData.rdd.collect().map(row => {
        var auditResult = 0
        val innum = row.getAs[Int]("innum")
        //获取数据时间的时分秒
        val time = String.valueOf(row.getAs[Timestamp]("datatime")).substring(11)
        //获取对应map中包含这个时间点的数据
        val mapArr = maps.filterKeys(_.substring(11).equals(time)).map(x => x._2)

问题原因:

  上面面代码中,我是将从数据库查询出来的数据"datatime"这个字段进行添加到maps中,而我使用的Timestamp类型,看下我数据库中该字段的类型:

  

  数据库中的该字段类型是datetime,本来我以为datetime对应到spark中的类型就是Timestamp,显然这样是会报上面的那个错的,如果当做String类型进行读取也是不行的,完全要按照datetime这个类型来进行修改,否则,数据读取出来之后可以添加到maps中,但是,对maps中的元素进行操作是会有问题的。接下来就是修改

改后部分代码:

val maps = Map[String, Int]()
      for (elem <- referenceData.collect()) {
        maps.put(String.valueOf(elem.getAs[DateTime]("datatime")), elem.getAs[Int]("innum"))
      }
      val exceptMsgs = auditData.rdd.collect().map(row => {
        var auditResult = 0
        val innum = row.getAs[Int]("innum")
        val time = String.valueOf(row.getAs[DateTime]("datatime")).substring(11)
        val mapArr = maps.filterKeys(_.substring(11).equals(time)).map(x => x._2)

修改之后,问题消失

转载于:https://www.cnblogs.com/Gxiaobai/p/10729106.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]中的错误信息是"fatal error: linux/compiler-gcc6.h: No such file or directory",这意味着编译器无法找到所需的文件。引用\[2\]提供了一种解决方法,即先安装libssl-dev:i386,然后再安装libssl-dev。引用\[3\]中提供了在不同Linux发行版上安装OpenSSL开发包的命令。根据这些信息,解决"fatal error: generated/bounds.h"的方法是根据你所使用的Linux发行版执行相应的命令来安装OpenSSL开发包。 #### 引用[.reference_title] - *1* [linux 内核编译 错误 fatal error: linux/compiler-gcc6.h: No such file or directory](https://blog.csdn.net/weixin_39618173/article/details/116881754)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [ubuntn PREEMPT_RT make 安装时 /usr/include/openssl/e_os2.h:13:11: fatal error: openssl/opensslconf.h...](https://blog.csdn.net/yiquan_yang/article/details/109679525)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [linux内核编译 fatal error: openssl/opensslv.h: No such file or directory](https://blog.csdn.net/sganchang/article/details/103609158)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值