weixin_43634763 2019-01-18 19:45 采纳率: 100%
浏览 3501
已采纳

使用updateByPrimaryKeySelective生成的sql语句的where后除了id还有其他字段???导致更新失败

我有两个service都用了updateByPrimaryKeySelective
有一个成功了还有一个失败了。该如何解决这个问题?

成功那个打印出的sql

2019-01-18 19:43:50.550 DEBUG 9924 --- [nio-8080-exec-6] c.p.h.m.u.P.updateByPrimaryKeySelective  : ==>  Preparing: UPDATE sys_permission SET id = id,parent_id = ?,sort = ?,per_type = ?,is_show = ? WHERE id = ? 

2019-01-18 19:43:50.550 DEBUG 9924 --- [nio-8080-exec-6] c.p.h.m.u.P.updateByPrimaryKeySelective  : ==> Parameters: 1(Integer), 12(Integer), 0(Integer), 1(Integer), 65(Integer)

失败那个打印出的sql

2019-01-18 19:30:27.376 DEBUG 9924 --- [nio-8080-exec-8] c.p.h.m.u.U.updateByPrimaryKeySelective  : ==>  Preparing: UPDATE sys_user SET id = ?,password = ?,phone = ?,update_time = ?,status = ?,rid = ? WHERE id = ? AND username = ? AND password = ? AND phone = ? AND gender = ? AND create_time = ? AND update_time = ? AND status = ? AND rid = ? 

2019-01-18 19:30:27.377 DEBUG 9924 --- [nio-8080-exec-8] c.p.h.m.u.U.updateByPrimaryKeySelective  : ==> Parameters: 2(Long), 123456(String), 123456654(String), 2019-01-18 19:30:27.376(Timestamp), 0(Integer), 1(Integer), 2(Long), null, 123456(String), 123456654(String), null, null, 2019-01-18 19:30:27.376(Timestamp), 0(Integer), 1(Integer)

  • 写回答

2条回答 默认 最新

  • weixin_43634763 2019-01-24 11:26
    关注

    终于发现问题所在,就是实体类的id用的是Long类型,而我service层用的是Integer类型,把实体类的也改为Integer就成功了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 docker环境配置
  • ¥20 绿盟安全扫描--检测到目标站点存在javascript框架库漏洞
  • ¥30 Android STD快速启动
  • ¥15 如何使用simulink建立一个永磁同步直线电机模型?
  • ¥30 天体光谱图的的绘制并得到星表
  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现