mybatis-plus的saveOrUpdate方法

saveOrUpdate,首先直接更新,如果更新失败返回0,接着发起查找,查询失败返回0,接着才是发起插入

问题:如何确定主键呢?

  • 插入的数据不带id

  • 插入的数据带id,且数据库存在

  • 插入的数据带id,且数据库不存在

插入的数据不带id

插入成功,而且mybatis-plus会帮你生成一个19位的id(1498495250845941762),策略为:mybatis-plus默认使用的主键生成的策略是IdType.ID_WORKER,根据类型随机产生一个全局唯一的id;

插入的数据带id且数据库存在

修改成功

插入的数据带id,且数据库不存在

插入成功

mybatis-plus找主键的方式

  • mybatis-plus本身是不知道你在数据库中创建的主键

  • 它以不太准确的默认规则寻找主键

  • 第一个情况:你的表中存在一个id字段,默认把id字段当做主键

  • 第二种情况:你给表字段加一个@TableId注解,主动让mybatis知道

  • 优先级注解比id更高

posted @ 2022-07-01 16:06  暮商  阅读(12976)  评论(0)    收藏  举报