JPA Save()对象后返回该对象在数据库中的ID的解决方法(亲测有效)
来源:互联网 发布:面包旅行 知乎 编辑:程序博客网 时间:2024/06/06 05:16
转载自: spring data jpa save问题
springdatajpa是很好用 的一个工具,但是!首先你要会用
今天下午就被一个spring-data-jpa的问题卡了略久,因为想要用MySQL自增id,想要在save之后获取这个保存的实体的id进行后续的工作,一直以为springdatajpa中的save方法执行结束之后,save(entity)中的entity就会自动被更新为保存的entity,但是其实不是这样的,今天用intellij的debug工具跟踪代码,发现save之后这个实体的id总是为0,既然这样那用save返回的entity的id总该行了吧,改了之后发现save返回的entity的id也是0,这就很尴尬了
上网谷歌一下,找到一个说要在save之后flush一下这个repository,然而试了之后并没有什么卵用
继续谷歌,发现一个springdatajpa的坑,springdatajpa其实是hibernate的一个比较高级的封装库,更好用了,但是底层还是用hibernate实现的,save方法其实就是hibernate的持久化方法,它是不会自动返回保存的实体的,那要怎么获取到这个保存的实体呢?
//该注解一定要在getter方法上@GeneratedValue(strategy = GenerationType.IDENTITY)public String getUserName(){ return userName;}
必须要加上这句话,spring data jpa才会知道你想要拿到这个保存后的实体,再返回这个实体
在你想要拿到自增id的列上加上@GeneratedValue,spring data jpa就会保存这个实体,并更新传入的实体为保存后的实体(其实就是hibernate返回了一下吧我觉得),这样的话,save(xxx)后xxx就已经更新为已经保存的实体了
spring-data-jpa之坑,记录备忘
- JPA Save()对象后返回该对象在数据库中的ID的解决方法(亲测有效)
- Hibernate 插入对象到数据库的同时返回该对象在数据库中生成的ID(自增)怎么做?
- sql2000备份的数据库还原到sql2005后,选择“数据库关系图”提示:此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- 让JPA的Query返回Map对象
- sql2005还原备份后,选择“数据库关系图”提示:此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- 函数返回对象的有效区
- spring jpa CrudRepository save 新建数据没有返回id
- "此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- "此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- "此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- "此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- Hibernate 注解方式 save后获取不到对象id一种情况
- TP框架中数据库操作add(),save(),delete()方法返回的都是操作行的主键值(id)
- “数据库关系图”提示:此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- 数据库关系图”提示:此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法(转)
- 数据库关系图”提示:此数据库没有有效所有者,因此无法安装数据库关系图支持对象"的解决方法
- hibernate save 后实体对象不会注销
- 获取某个树节点下所有叶子节点,同时要求叶子节点是同一类对象,要求返回该叶子节点对象的id集合
- python的ConfigParser模块
- Java程序的运行
- 微信小程序------联动选择器
- jsBOM操作初步学习
- 1.一些不错文章
- JPA Save()对象后返回该对象在数据库中的ID的解决方法(亲测有效)
- python中的可变与不可变数据类型
- HDU 1535 Invitation Cards SPFA
- 自信心、自制力。Java
- keil5工具的相关配置
- Tftp32连接开发板遇到的问题
- C++文件操作——ini文件读取与写入
- linux-函数及应用
- “响应国务院鼓励区块链应用试点号召”座谈会成功召开