详解mybatis plus使用insert没有返回主键的处理

所属分类: 数据库 / mssql2008 阅读数: 773
收藏 0 赞 0 分享

项目使用springboot搭建。最初的时候是使用mybatis,后来升级到mybatis plus。按照mp的官网介绍,使用mp的insert方法,对于自增的数据库表,mp会把主键写入回实例的对应属性。但实际操作起来,却没有主键。

entity 类设置如下:

@TableName(value = "USERINFO")
public class UserInfo {
  /**
   * 指定自增策略
  */
  @TableId(value = "user_id",type = IdType.AUTO)
  private Long userId;

  private String gender;

  private Date birthday;

  private String phone;
//省略后面的其他属性和getter/setter
}

dao 类设置如下:

@Repository
@Mapper
public interface UserInfoDao extends BaseMapper<UserInfo> {
  //  int insert(UserInfo record);

  int insertSelective(UserInfo record);

  UserInfo selectByPrimaryKey(Long logId);

  int updateByPrimaryKeySelective(UserInfo record);
}

Service类调用userInfoDao的insert方法(此方法是来源于BaseMapper)。但是insert成功后没有返回主键userId。上网查了下,其他人都是这样设置,就会有主键返回。

看到dao类里面一条注释,// int insert(UserInfo record); ,心里有个想法。

这条注释对应的insert方法,是使用mybatis generator生成的。但是因为此方法名和mybatis plus的通用方法名一样,所以我把它注释了。会不会是因为dao对应的mapper.xml文件,里面的id = inesert的sql语句依然存在,从而覆盖掉了mybatis plus的通用insert,所以没有自动返回主键。

点进去对应mapper.xml文件,果然看到<insert id="insert">的sql语句。删掉该语句,重试mybatis plus的insert方法,这次有主键返回了。

更多精彩内容其他人还在看

SQLServer2008新实例远程数据库链接问题(sp_addlinkedserver)

这篇文章主要介绍了SQLServer2008新实例远程数据库链接问题(sp_addlinkedserver),需要的朋友可以参考下
收藏 0 赞 0 分享

Sql Server 2008安裝图文教程

这篇文章主要介绍了Sql Server 2008安裝图文教程,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server 2008中SQL查询语句字段值不区分大小写的问题解决

这篇文章主要介绍了关于SQL Server 2008中SQL查询语句字段值不区分大小写问题的解决方法,文中将解决方法介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
收藏 0 赞 0 分享

SQL Server 2008打开输入sa密码提示无法登陆数据库的解决方法

与 SQL Server建立连接时出现与网络相关的或特定于实例的错误,这篇文章主要介绍了SQL Server 2008打开输入sa密码提示无法登陆数据库的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

SQL SERVER 2008数据库日志文件收缩的方法

这篇文章主要为大家详细介绍了SQL SERVER 2008数据库日志文件收缩的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

sql server2008数据库迁移的两种方法

这篇文章主要为大家详细介绍了sql server2008数据库迁移的两种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

解决sql server2008注册表写入失败,vs2013核心功能安装失败

本文给大家分享的是作者在更换硬盘后全新安装sql server2008以及VS2013的过程中遇到的注册表无法写入的问题以及解决方法,分享给大家,希望大家能够喜欢
收藏 0 赞 0 分享

SQL Server 2008 R2 为用户权限分配的操作步骤

这篇文章主要介绍了SQL Server 2008 R2 为用户权限分配的操作步骤,有时候我们不得不设置一些权限,例如禁止删除等,那么就可以参考下面的方法
收藏 0 赞 0 分享

Sql Server 2008数据库新建分配用户的详细步骤

当一个项目完成后,为了数据安全,总会对该项目的数据库分配一个用户,应该说总会创建一个用户来管理这个数据库,并且这个用户只能管理这个数据库,绝对不要使用sa用户
收藏 0 赞 0 分享

Sql Server 2008R2升级Sql Server 2012图文教程

这篇文章主要分享了了Sql Server 2008R2升级Sql Server 2012图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多