mybatis批量写入JSONArray

java  发送 http json请求后返回json数据

接收后存入数据库

接收的数据格式

 {"code":0"data":[{"data":"1381.59997558593"13815999755859375  "time":"1683319534158"1},{data : 1381 599975581.5999755859375 ,"time":"1683319534}]

task.java

  /**
     * 返回值 类型 {"code":0"data":[{"data":"1381.59997558593"13815999755859375  "time":"1683319534158"1},
     *{data : 1381 599975581.5999755859375 ,"time":"1683319534}]
     */
    public  void pullData(){
        String url = "http://XXXXXX/systemcfg";
        JSONObject param = new JSONObject();
        param.put("request","XXXXXX");
        param.put("token","XXXXXXXXX");
        JSONObject j = new JSONObject();
        j.put("suid","XXX");
        j.put("cuid","XXX");
        param.put("value",j);
        System.out.println(param.toString());
        String s = HttpUtils.sendPost(url, param.toJSONString());
        System.out.println(s);
        JSONObject parse =(JSONObject) JSONObject.parse(s);
        JSONArray data1 = parse.getJSONArray("data");
//        Object[] data = FastJsonUtil.toArray(.toJSONString(), R3Volapu.class);
        System.out.println(data1.toString());
        r3VolapuMapper.insertR3VolapuBetch(data1,"1703","128");
    }

mapper.java

   int insertR3VolapuBetch(@Param("r3Volapus") JSONArray r3Volapus, @Param("suid") String suid, @Param("cuid") String cuid );

 mapper.xml

 <insert id="insertR3VolapuBetch" parameterType="arraylist">
        insert into r3_volapu(suid, cuid,`data` , `time`) values
        <foreach collection="r3Volapus" item="item"  separator=",">
            (#{suid},#{cuid},#{item.data},#{item.time})
        </foreach>
    </insert>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MyBatis中,如果你的查询结果中包含JSONArray类型的数据,你可以使用MyBatis-Plus提供的注解@TableField(typeHandler = JacksonTypeHandler.class)来指定对应字段的类型处理器。在你的Java实体类中,使用这个注解来标注JSONArray类型的字段,这样在查询结果映射时,MyBatis就会使用JacksonTypeHandler来处理这个字段的数据类型。\[1\]\[3\] 举个例子,你可以在查询方法中组装参数,将JSONArray对象放入Map中,然后调用相应的查询方法。在查询结果中,你就可以得到返回的JSONArray数据了。\[2\] 需要注意的是,你需要在项目中引入MyBatis-Plus的依赖,并正确配置MyBatis-Plus的相关配置,才能使用@TableField注解和JacksonTypeHandler类型处理器。 #### 引用[.reference_title] - *1* *3* [【JavaMybatis查询数据库返回JSON格式的字段映射到实体类属性](https://blog.csdn.net/Syals/article/details/129798458)[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_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [mybatis 传入参数为jsonArray如何处理](https://blog.csdn.net/King__Jrj/article/details/121428391)[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_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

somdip

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值