解决接收POST数组参数并一条SQL批量删除数据

当前端POST参数为数组时,如:

[
 { attrId: 4, attrGroupId: 3 },
 { attrId: 1, attrGroupId: 2 }
]

接收参数要使用@RequestBody,可以设置一个实体类以数组方式接收:

    /**
     * 删除关联关系
     */
    @RequestMapping("/attr/relation/delete")
    public R deleteAttrRelation(@RequestBody AttrAttrgroupRelationEntity[] attrRelation) {
        attrGroupService.deleteBatchRelation(attrRelation);
        return R.ok();
    }

要将接收到的数组 [] 转换为 List<T>方式

     /**
     * 删除关联关系(可批量删除)
     */
    @Override
    public void deleteBatchRelation(AttrAttrgroupRelationEntity[] attrRelation) {
        // 把数组转化为实体List属性
        List<AttrAttrgroupRelationEntity> entities = Arrays.asList(attrRelation).stream().collect(Collectors.toList());
        this.baseMapper.deleteBatchRelation(entities);
    }

批量删除:

@Mapper
public interface AttrGroupDao extends BaseMapper<AttrGroupEntity> {
    void deleteBatchRelation(@Param("entities") List<AttrAttrgroupRelationEntity> entities);

}


在Dao.xml里设置循环
<delete id="deleteBatchRelation">
   DELETE FROM `pms_attr_attrgroup_relation` WHERE
   <foreach collection="entities" item="item" separator="OR">
       attr_group_id = #{item.attrGroupId} and attr_id = #{item.attrId}
   </foreach>
</delete>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用axios进行post请求时,如果要传递一个数组作为参数,你可以使用qs库将数组参数序列化为字符串。首先,你需要导入axios和qs库,然后使用qs.stringify()方法将数组参数进行序列化。例如,你可以这样写代码: import axios from 'axios' import qs from 'qs' axios.post(url, qs.stringify({ ids: [1, 2, 3] })) .then((res) => { // 处理响应 }) 在这个例子中,ids参数是一个数组,通过qs.stringify()方法将其序列化为字符串。然后,使用axios.post()方法发送post请求,并将序列化后的参数作为请求体发送到服务器。最后,你可以在.then()方法中处理响应。这样就可以成功将数组作为参数传递给后台接口了。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [axios传递数组参数](https://blog.csdn.net/sunrj_niu/article/details/106804840)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [axios向后台传递数组作为参数的方法](https://download.csdn.net/download/weixin_38628211/13658162)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值