Mybatis Plus插入数据后获取新数据id值的踩坑记录

目录
  • 问题描述:
  • 解决方法:
  • 总结

问题描述:

Mybatis Plus的insert方法,按说插入数据后会自动返回id

mapper方法:

@DS("wxuser")
@Mapper
public interface UserInfoMapper extends BaseMapper<UserInfo> {

}

业务类:

		@Autowired
		UserInfoMapper userInfoMapper;

		UserInfo user = new UserInfo();
        user.setAddress(userInfo.getAddress());
        user.setAge(userInfo.getAge());
        user.setMobile(userInfo.getMobile());
        user.setCreateTime(new Date());
        user.setUpdateTime(new Date());
        // 此num是指的插入数据成功的条数
        int num = userInfoMapper.insert(user);
        //如果想要获取插入数据的id,需要:user.getUserId();
        int id = user.getUserId();

这样按说是可以的,但是我这里仍然获取不到,所以需要再修改。

解决方法:

修改后mapper类:

@DS("wxuser")
@Mapper
public interface UserInfoMapper extends BaseMapper<UserInfo> {
    int saveUserInfo(@Param("userInfo")UserInfo userInfo);
}

在resources目录中新建mapper目录,创建UserInfoMapper.xml文件:

注意三个值:

useGeneratedKeys=“true”

说明:允许 JDBC 支持自动生成主键,需要数据库驱动支持。如果设置为 true,将强制使用自动生成主键。尽管一些数据库驱动不支持此特性,但仍可正常工作(如 Derby)。

(仅适用于 insert 和 update)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的自动递增字段),默认值:false。

keyProperty=“userInfo.userId”

说明:keyProperty中对应的值是实体类的属性,而不是数据库的字段

keyColumn=“userId”

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.wx.user.mapper.UserInfoMapper">

    <insert id="saveUserInfo" useGeneratedKeys="true" keyProperty="userInfo.userId" keyColumn="userId">
        insert into userInfo (userNick,userName,password,isdelete,address,mobile)  values (#{userInfo.userNick},#{userInfo.userName},#{userInfo.password},#{userInfo.isDelete},#{userInfo.address},#{userInfo.mobile})
    </insert>

</mapper>

application.yml文件中:

# Mybatis Plus
mybatis-plus:
  configuration:
    map-underscore-to-camel-case: false # 设置字段不使用下划线方式
  global-config:
    db-config:
      id-type: AUTO
      table-underline: false # 设置表名字不使用下划线方式
  mapper-locations: classpath*:/mapper/**/*.xml

修改后的业务类:

		@Autowired
		UserInfoMapper userInfoMapper;

		UserInfo user = new UserInfo();
        user.setAddress(userInfo.getAddress());
        user.setAge(userInfo.getAge());
        user.setMobile(userInfo.getMobile());
        user.setCreateTime(new Date());
        user.setUpdateTime(new Date());
        // 此num是指的插入数据成功的条数
        int num = userInfoMapper.saveUserInfo(user);
        //如果想要获取插入数据的id,需要:user.getUserId();
        int id = user.getUserId();

这样就可以获取到新插入数据的id值了

总结

到此这篇关于Mybatis Plus插入数据后获取新数据id值的文章就介绍到这了,更多相关Mybatis Plus获取新数据id值内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Mybatis-plus全局id生成策略详解

    Mybatis-plus全局id生成策略 在配置文件中加入以下代码后就不需要在实体类种的id上添加 @TableId(value = "id", type = IdType.AUTO) mybatis-plus:   global-config:     db-config:       id-type: auto #设置主键自动生成策略(全局id生成策略) Mybatis-plus6种主键生成策略小结 /** * 数据库ID自增,数据库需要支持主键自增(如MySQL),并设置主键自增

  • mybatis-plus添加数据时id自增问题及解决

    目录 mybatis-plus添加数据时id自增问题 解决方案 插入记录的主键自增赋值机制说明 代码说明 1.找到执行入口 2.看看keyGenerator的执行逻辑 3. 跟进逻辑执行 4.继续进入下一层逻辑 5.继续进入下一层逻辑 6.关键取值 7.关键赋值 自增主键 UUID mybatis-plus添加数据时id自增问题 mybatis-plus插入数据,id自增列变的很长.比如下图: mybatis-plus中遇到一个,添加数据到数据库,而数据库中的id列是自增列 使用plus中自带的

  • Mybatis-Plus 新增获取自增列id方式

    目录 新增获取自增列id 1.实体类定义 2.解决办法 3.调用方法获取id说明 解决id自增方法 新增获取自增列id 1.实体类定义 注意:@TableId(value = “id”, type = IdType.AUTO)注解中的 type = IdType.AUTO 属性标注主键为自增策略. import lombok.Data; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatispl

  • 一览画面点击复选框后获取多个id值的方法

    在web开发中经常会遇到一览画面中每一条记录前都带一个复选框,点击后选中该条记录进行删除.修改.查看等操作. 修改和查看都是获取一条记录的id值后传递到后台进行查询获取该记录对象的各种属性值,再显示到画面上. 我说的重点是选中多条记录后进行批量删除,如何获取多条记录的id值是问题的关键.首先是在jsp页面中全选中复选框的方法. 代码如下: function checkEvent(name, allCheckId) { var allCk = document.getElementById(all

  • MybatisPlus中插入数据后获取该对象主键值的实现

    实体对象 主键IdType要设置为AUTO 表示数据库ID自增 @Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) public class Employee implements Serializable { private static final long serialVersionUID = 1L; @TableId(value = "id", type = IdType.AUTO) priv

  • 解决SpringBoot框架因post数据量过大没反应问题(踩坑)

    此处网上最多的做法是需要修改tomcat的参数配置大致如下: <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="2000" redirectPort="8443" URIEncoding="UTF-8" maxThreads="3000" compression="on" compress

  • Javascript 阻止javascript事件冒泡,获取控件ID值

    1. 如何阻止事件冒泡 复制代码 代码如下: //非IE if (event && event.stopPropagation) event.stopPropagation(); else//IE window.event.cancelBubble = true; 2.获取控件ID 复制代码 代码如下: if (document.all) { //IE alert(event.srcElement.tagName+":"+event.srcElement.id); }

  • jquery的flexigrid无法显示数据提示获取到数据

    升级了IE10,发现flexigrid无法显示数据,提示获取到了数据,但没任何报错任何显示.截图如下. 跟踪代码,发现内部是生成了td,tr和要显示的数据,但没有显示出来. 经过试验和跟踪,修改如下. 在addData中修改 复制代码 代码如下: $(t).append(tbody); 为 $(t).append('<table cellpadding=0 cellspacing=0>'+tbody.outerHTML + '</table>'); 这样数据就能正常显示了.

  • sql清空表数据后重新添加数据存储过程的示例

    复制代码 代码如下: ALTER PROCEDURE [dbo].[sp_add_Jurisdiction]@CTableName varchar(20), --当前要删除.新增的表@filedkeyValue varchar(20), --要删除的字段值@filedName varchar(20), --要删除的字段名@filedNameAdd1 varchar(20), --要新增的字段名1@filedNameAdd2 varchar(20), --要新增的字段名2@sql varchar(

  • .net实现oracle数据库中获取新插入数据的id的方法

    在sql sever中实现插入数据的自动增长是很容易的,但是在oracle数据库中实现这一操作不是很容易,同时要想在.net中实现获取新插入数据的id,而且不会出现读错的情况,就更显得困难了,为了解决在oracle数据中插入的数据能够自增id,同时获取新数据的id,并避免因并发操作而出现的id读错的问题. 数据表结构为test(id,name) 首先,解决数据id自增问题 创建一个序列sequence(sequence详解可从网上搜一下,这里不赘述) create sequence SEQ_te

  • Mybatis实现插入数据后返回主键过程解析

    添加记录后获取主键ID,这是一个很常见的需求,特别是在一次前端调用中需要插入多个表的场景. 除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值. 一.获取新添加记录主键字段值 注意: 在MyBatis中添加操作返回的是记录数并非记录主键id. 如果需要获取新添加记录的主键值,需要在执行添加操作之后,直接读取Java对象的主键属性. Integer rows = sqlSession.getMapp

  • Vue实现渲染数据后控制滚动条位置(推荐)

    需求场景如下: 实现了消息发送,如果容器内消息过多,会出现滚动条,最新的消息位于最底部,不能及时出现在可视区域内,此时就需要在渲染列表后,将滚动条的位置定位到最底部.先来看看最终实现的效果 实现思路 渲染完数据后,通过refs对象获取消息容器的实际高度 将滚动条的设置到最底部 实现过程 sendMessage: function (event) { // 数据渲染 this.senderMessageList.push(thisSenderMessageObj); // 改变滚动条位置 this

  • Python3 操作 MySQL 插入一条数据并返回主键 id的实例

    Python 中貌似并没有直接返回插入数据 id 的操作(反正我是没找到),但是我们可以变通一下,找到最新插入的数据 #!/usr/bin/env python3 # -*- coding: UTF-8 -*- import pymysql db = pymysql.connect(**db_conf) cursor = db.cursor() cursor.execute(sql) # 最后插入行的主键id print(cursor.lastrowid) # 最新插入行的主键id print(

随机推荐

其他