修改或者新增数据 使用一个方法

因为修改或者新增数据 唯一的区别就是数据库中是否有该条数据,所以 在Controller 层中 判断id是否存在即可

Controller

@RestController
@RequestMapping("riskunit")
public class SUnitController extends MpBaseController{
   /**
     * 新增或修改风险单元
     */
    @Log(title = "风险单元", businessType = BusinessType.INSERT)
    @RequiresPermissions("scyf:riskunit:addOrUpdate")
    @PostMapping
    public AjaxResult add(@Validated @RequestBody SUnit sUnit){
        if (sUnit.getUnitId() == null) {
            boolean b = sUnitService.addUnit(sUnit);
            if (b) {
                return AjaxResult.success("新增成功");
            }
            return AjaxResult.error("新增失败");
        }else {
            boolean b = sUnitService.updateUnit(sUnit);
            if (b) {
                return AjaxResult.success("修改成功");
            }
            return AjaxResult.error("修改失败");
        }
    }
}

Service

public interface SUnitService extends IService<SUnit> {
    boolean addUnit(SUnit sUnit);

    boolean updateUnit(SUnit sUnit);
}

ServiceImpl

@Service
public class SUnitServiceImpl extends ServiceImpl<SUnitMapper, SUnit> implements SUnitService {
    @Override
    public boolean addUnit(SUnit sUnit) {
        sUnit.setCreateTime(getDate());
        int insert = sUnitMapper.insert(sUnit);
        boolean b = addSRF(sUnit.getIds(), sUnit.getUnitId());
        if (insert == 1 && b){
            return true;
        }
        return false;
    }

    @Override
    public boolean updateUnit(SUnit sUnit) {
        sUnit.setUpdateTime(getDate());
        QueryWrapper<SUnit> wrapper = new QueryWrapper<>();
        wrapper.eq("unit_id",sUnit.getUnitId());
        int update = sUnitMapper.update(sUnit, wrapper);
        boolean b = updateSRF(sUnit.getIds(), sUnit.getUnitId());
        if (update == 1 && b){
            return true;
        }
        return false;
    }
    public boolean addSRF(Integer[] ids,Integer unitId){
        int j = 0;
        for (int i = 0; i < ids.length; i++) {
            SRiskFactors sRiskFactors = new SRiskFactors();
            sRiskFactors.setUnitId(unitId);
            sRiskFactors.setFacId(ids[i]);
            int insert1 = sRiskFactorsMapper.insert(sRiskFactors);
            if (insert1 == 1){
                j++;
            }
        }
        if (ids.length == j){
            return true;
        }
        return false;
    }
    public boolean updateSRF(Integer[] ids,Integer unitId) {
        QueryWrapper<SRiskFactors> wrapper = new QueryWrapper<>();
        wrapper.eq("unit_id", unitId);
        sRiskFactorsMapper.delete(wrapper);
        boolean b = addSRF(ids, unitId);
        return b;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值