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