转载自: 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的持久化方法,它是不会自动返回保存的实体的,那要怎么获取到这个保存的实体呢?

//该注解可以在Id字段上,可以在Id字段的getter方法上
 @Id
 @GeneratedValue(strategy = GenerationType.IDENTITY)
 private int id;

@GeneratedValue(strategy = GenerationType.IDENTITY)
public String getId(){
	return id;
}

必须要加上这句话,spring data jpa才会知道你想要拿到这个保存后的实体,再返回这个实体
在你想要拿到自增id的列上加上@GeneratedValue,spring data jpa就会保存这个实体,并更新传入的实体为保存后的实体(其实就是hibernate返回了一下吧我觉得),这样的话,save(xxx)后xxx就已经更新为已经保存的实体了

spring-data-jpa之坑,记录备忘

Logo

快速构建 Web 应用程序

更多推荐