tk.Mybatis 插入数据获取Id问题
作者:武汉加油、中国加油 发布时间:2023-07-01 22:03:13
1、问题描述
几种代码写法会有不同的ID
返回值,下面我们一一分析。
2、问题分析
首先一种插入写法,源码如下:
SysUser .java
/**
* 用户管理(SysUser)实体类
*
* @author Chen
* @since 2020-05-06 14:16:48
*/
@Data
@ApiModel("用户管理")
public class SysUser implements Serializable {
private static final long serialVersionUID = 993569543176442301L;
/**
* 编号
*/
@Id
private Long id;
/**
* 用户名
*/
private String name;
/**
* 昵称
*/
private String nickName;
/**
* 头像
*/
private String avatar;
/**
* 密码
*/
private String password;
/**
* 加密盐
*/
private String salt;
/**
* 邮箱
*/
private String email;
/**
* 手机号
*/
private String mobile;
/**
* 状态 0:禁用 1:正常
*/
private Object status;
/**
* 机构ID
*/
private Long deptId;
/**
* 创建人
*/
private String createBy;
/**
* 创建时间
*/
private Date createTime;
/**
* 更新人
*/
private String lastUpdateBy;
/**
* 更新时间
*/
private Date lastUpdateTime;
/**
* 是否删除 -1:已删除 0:正常
*/
private Object delFlag;
}
测试类
@Test
void insert() {
SysUser sysUser = new SysUser();
sysUser.setName("zhangsan3");
sysUser.setNickName("张三3");
SysUser insert = sysUserService.insert(sysUser);
System.out.println(insert);
}
结果输出:
SysUser(id=null, name=zhangsan3, nickName=张三3, avatar=null, password=null, salt=null, email=null, mobile=null, status=null, deptId=null, createBy=null, createTime=null, lastUpdateBy=null, lastUpdateTime=null, delFlag=null)
是的我们获取到的是id=null
,这显然不符合我们的预期。于是修改代码。只改测试类。比如输入id=0
。源码如下:
@Test
void insert() {
SysUser sysUser = new SysUser();
sysUser.setId(0L);
sysUser.setName("zhangsan6");
sysUser.setNickName("张三6");
SysUser insert = sysUserService.insert(sysUser);
System.out.println(insert);
}
再次运行程序,控制台输出如下:
SysUser(id=0, name=zhangsan4, nickName=张三4, avatar=null, password=null, salt=null, email=null, mobile=null, status=null, deptId=null, createBy=null, createTime=null, lastUpdateBy=null, lastUpdateTime=null, delFlag=null)
嗯,好像确实输出了id=0
,符合我们的预期,但是真的是这样吗?我们看看数据库限制是什么样。
没错,我们的真实id
是38。这里就有问题了。查阅相关资料说是在实体类中添加@GeneratedValue(strategy = GenerationType.IDENTITY)
就可以了。于是我们照做。修改实体类如下:
/**
* 用户管理(SysUser)实体类
*
* @author Chen
* @since 2020-05-06 14:16:48
*/
@Data
@ApiModel("用户管理")
public class SysUser implements Serializable {
private static final long serialVersionUID = 993569543176442301L;
/**
* 编号
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
/**
* 用户名
*/
private String name;
/**
* 昵称
*/
private String nickName;
/**
* 头像
*/
private String avatar;
/**
* 密码
*/
private String password;
/**
* 加密盐
*/
private String salt;
/**
* 邮箱
*/
private String email;
/**
* 手机号
*/
private String mobile;
/**
* 状态 0:禁用 1:正常
*/
private Object status;
/**
* 机构ID
*/
private Long deptId;
/**
* 创建人
*/
private String createBy;
/**
* 创建时间
*/
private Date createTime;
/**
* 更新人
*/
private String lastUpdateBy;
/**
* 更新时间
*/
private Date lastUpdateTime;
/**
* 是否删除 -1:已删除 0:正常
*/
private Object delFlag;
}
主要就是改了这里。OK,继续运行程序,结果如下:
SysUser(id=0, name=zhangsan5, nickName=张三5, avatar=null, password=null, salt=null, email=null, mobile=null, status=null, deptId=null, createBy=null, createTime=null, lastUpdateBy=null, lastUpdateTime=null, delFlag=null)
这里的id
还是0,什么鬼。再看看数据库。
明显不是0。所以这里不能设置id的属性。修改测试类。源码如下:
@Test
void insert() {
SysUser sysUser = new SysUser();
sysUser.setName("zhangsan6");
sysUser.setNickName("张三6");
SysUser insert = sysUserService.insert(sysUser);
System.out.println(insert);
}
继续运行程序,结果如下:
SysUser(id=40, name=zhangsan6, nickName=张三6, avatar=null, password=null, salt=null, email=null, mobile=null, status=null, deptId=null, createBy=null, createTime=null, lastUpdateBy=null, lastUpdateTime=null, delFlag=null)
这次id=40
了,查看数据库。
很明显对上了。
3、总结
来源:https://blog.csdn.net/qq_32510597/article/details/105951408


猜你喜欢
- 一、创建数据库 1、新建数据库帮助类 包名——右击—&am
- 本文实例为大家分享了Android Studio实现帧动画的具体代码,供大家参考,具体内容如下按一定的顺序播放静态的图片1、几张联系的图片2
- 本文实例为大家分享了Java swing读取txt文件实现学生考试系统的具体代码,供大家参考,具体内容如下主要实现了一个简单的倒计时答题系统
- 循环依赖定义循环依赖就 循环引用,就是两个或多个 bean 相互之间的持有对方,比如 CircleA 引用 CircleB , Circle
- 在很多语音视频软件系统中,经常有将实时的音频或视频录制为文件保存到磁盘的需求,比如,视频监控系统中录制监控到的视频、视频会议系统中录制整个会
- 用了MyBatis的同行,应该见过foreach,它一般是这样用的:<select id="foreachTest"
- Dubbo作为国内最出名的分布式服务框架,是Java程序员必备必会的框架之一,更是中高级测试面试过程中经常会问的技术,无论你是否用过,你都必
- Javaweb分页技术实现分页技术就是通过SQL语句(如下)来获取数据,具体实现看下面代码//分页查询语句select * from 表名
- 前言这个东西有啥用,好玩?确实, 好玩归好玩,其实很有使用场景。可以自己选则一些业务节点触发这个机器人助手的消息推送;简单举例:1. 有人给
- Java的集合类是一种特别有用的工具,它可以用于存储数量不等的多个对象,并可以实现常用的数据结构,如栈、队列等。Java集合还可以用于板寸具
- 下面提供三种计时器的写法供大家参考,大家可以自行选择自己钟爱的使用。写法一(Spring 包提供的计时器):import java.text
- 本文章主要讲二维数组定义,用法。1.什么是二维数组在二维数组多个元素为一维数组的数组就称为二维数组2.定义格式格式一:元素的数据类型[][]
- 异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。比如说,你的代码少了一个分号,那么运行出来结果是提示是错误
- 本文实例为大家分享了Unity排行榜优化滚动效果的具体代码,供大家参考,具体内容如下自己做的一个优化排行榜的功能,当有大量的数据需要在scr
- 本篇使用java自带的MessageDigest实现对文本的md5加密算法,具体代码如下: /** *@Description
- 前言上一篇我们认识了Kotlin编程语言,也搭建好开发环境。本篇就进入Kotlin的基础语法介绍,与其他编程语言一样,Kotlin也有自己的
- 本文实例为大家分享了opencv实现轮廓高斯滤波平滑的具体代码,供大家参考,具体内容如下一个小测试的题目:在图像上点选,找到与点选处相邻的颜
- 首先我们建立两个数据库(可以不在同一台电脑上):multiple_order:DROP DATABASE IF EXISTS `multip
- RestTemplate设计是为了Spring更好的请求并解析Restful风格的接口返回值而设计的,通过这个类可以在请求接口时直接解析对应
- 日志输出是所有系统必备的,很多开发人员可能因为常常使用log4j而忽视了JDK logging模块,两者之间是否有联系?是怎样的联系?JDK