mybatis的updateById()出现问题时候,最好在mapper自己写一个方法....

mybatis的updateById出现问题,修改后但是数据库的表没有真正修改

这个问题用人话来说是:

(1)表里面有1、2、3、4,我现在要删掉数字4;

         但是删掉时候前端显示是4变成空字符串“”;

(2)去数据库的表看还是1、2、3、4;

(3)所以是updateById出现问题

还是乖乖地去mapper写SQL语句

原始SQL UPDATE 语句

UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;

要自定义的SQL语句(实现功能和updateById一样)

UPDATE M_AIRPORT_CATEGORY
SET airport_type_name=#{airportTypeName},desc_id=#{descId},remarks=#{remarks},create_time=#{createTime},create_code=#{createCode},create_user_name=#{createUserName} 
WHERE id=#{id}

mapper

@Mapper
public interface MairportCategoryMapper extends BaseMapper<MairportCategory> {


    @Select("UPDATE M_AIRPORT_CATEGORY\n" +
            "SET airport_type_name=#{airportTypeName},desc_id=#{descId},remarks=#{remarks},create_time=#{createTime},create_code=#{createCode},create_user_name=#{createUserName}\n" +
            "WHERE id=#{id};")
    Integer updateModel(@Param("id") String id, @Param("airportTypeName") String airportTypeName, @Param("descId") Integer descId, @Param("remarks") String remarks
            , @Param("createTime") Date createTime, @Param("createCode") String createCode, @Param("createUserName") String createUserName);

}

为什么返回值用Integer,而不是List, 因为前者只是编辑修改,后者是查询才返回List

SQL语句里面的参数都是对应实体类MairportCategory里面的

回到serviceImpl

 @Override
    public Integer AirportTypeEdit(MairportCategoryVO model) {
        try {
//            MairportCategory resultModel = new MairportCategory();
//            BeanUtils.copyProperties(model, resultModel);
            //updateById只能操作数据库的实体类对象 MairportCategory resultModel ,而不能直接操作前端实体类对象 MairportCategoryVO model
            //return airportCategoryMapper.updateById(resultModel);

            //自己写的mapper方法就可以直接操作前端实体类对象 MairportCategoryVO model
            return airportCategoryMapper.updateModel(model.getId(), model.getAirportTypeName(), model.getDescId(), model.getRemarks(), model.getCreateTime(), model.getCreateCode(), model.getCreateUserName());
        }catch (Exception ex) {
            LOG.error("AirportTypeEdit修改机场分类报错,错误信息" + ex.getMessage());
            return 0;
        }
    }

这时候编辑就能成功了

附上当时发现bug的前端payload

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值