zoukankan      html  css  js  c++  java
  • 原创:Mybatis批量插入转换成list集合的问题以及解决方案(转载请注明出处,谢谢!)

    问题:

    由于项目中需要批量插入的功能,然后我就用到了阿里的json包,将json数据转换成list集合在批量添加到数据库,但是这个过程中,我突然发现一个问题,之前接收前台传来的值是有的,但转换之后某些字段的值没有了,后面发现,原来是Mybatis自动生成插件做的怪,将实体类赋setter和getter方法时,并没有将属性大写,也就是说原本我的实体字段为gName;setter方法之后为setgName,这就违反了命名规则,但是阿里json包就出现了不能转换报Null的问题,经过试验,终于找到了解决方案:

    解决方案:

         1.如果你不想用别的方法,且Pojo类字段不是很多的话,直接将所有的setter和getter方法去掉,用eclipse自动生成的setter和getter方法

         2.

                JSONArray Array1 = JSONArray.fromObject(Declaration);
                //List<CustomsDeclareBillDetail> detail = Array1.toList(Array1, CustomsDeclareBillDetail.class);

                  当然,这种方法是已经废弃的,但是还可以使用,至于有什么漏洞我就不知道了

    3. 

             JSONArray jsonArray = JSONArray.fromObject(json);
              List<String> list2 = (List) JSONArray.toCollection(jsonArray);

             这种方法的结果和上面是一样的,但还是极力推荐使用这种方案。

    如果我的总结给你解决了问题,请顶一下文吧~

  • 相关阅读:
    SQL Injection
    yum命令不能使用的相关错误
    linux下RTNETLINK answers: File exists的解决方案
    XShell上传、下载文件(使用sz与rz命令)!
    Linux中iptables设置详细
    linux shell awk用法
    linux sed命令 用法
    Tcpdump 的用法
    VIM文本替换命令
    linux的tar命令详情;linux多个文件压缩打包到一个压缩文件
  • 原文地址:https://www.cnblogs.com/jbml-154312/p/7428203.html
Copyright © 2011-2022 走看看