其他分享
首页 > 其他分享> > mybatis的updateById()出现问题时候,最好在mapper自己写一个方法....

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

 

标签:mapper,updateById,create,....,Param,remarks,model,id
来源: https://blog.csdn.net/m0_47185078/article/details/121939230