ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2021-12-14 21:00:27  阅读:388  来源: 互联网

标签:mapper updateById create .... Param remarks model id


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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有