微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Spring JPA错题实例代码分析

今天小编给大家分享一下Spring JPA错题实例代码分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor

详细报错

com.fasterxml.jackson.databind.exc.InvalidDeFinitionException: No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.example.sbjdemo.pojo.User["car"]->com.example.sbjdemo.pojo.Car$HibernateProxy$CCqaurKR["hibernateLazyInitializer"])
	at com.fasterxml.jackson.databind.exc.InvalidDeFinitionException.from(InvalidDeFinitionException.java:77) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.SerializerProvider.reportBadDeFinition(SerializerProvider.java:1300) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.DatabindContext.reportBadDeFinition(DatabindContext.java:400) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.impl.UnkNownSerializer.failForEmpty(UnkNownSerializer.java:46) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.impl.UnkNownSerializer.serialize(UnkNownSerializer.java:29) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:728) ~[jackson-databind-2.13.5.jar:2.13.5]
...........

触发场景

当fetch设置为懒加载的时候(fetch = FetchType.LAZY),进行查询操作

错误原因

car在转化为json的时候,序列化失败了(大概就是这个意思吧)

解决办法

在序列化失败的实体类添加 @JsonIgnoreProperties(value = {"hibernateLazyInitializer"})

二、java.lang.StackOverflowError: null

详细报错

java.lang.StackOverflowError: null
	at java.lang.classLoader.defineClass1(Native Method) ~[na:1.8.0_212]
	at java.lang.classLoader.defineClass(ClassLoader.java:763) ~[na:1.8.0_212]
	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) ~[na:1.8.0_212]
	at java.net.urlclassloader.defineClass(urlclassloader.java:468) ~[na:1.8.0_212]
	at java.net.urlclassloader.access$100(urlclassloader.java:74) ~[na:1.8.0_212]
	at java.net.urlclassloader$1.run(urlclassloader.java:369) ~[na:1.8.0_212]
	at java.net.urlclassloader$1.run(urlclassloader.java:363) ~[na:1.8.0_212]
	at java.security.AccessController.doPrivileged(Native Method) ~[na:1.8.0_212]

触发场景

两个关联的实体类都有外键字段,且都有关联注解,如:@OnetoOne、@OnetoManay、@ManyToOne、@ManyToMany

错误原因

两个相关联的对象互相调用并打印,形成一个递归调用,最后堆栈溢出

解决办法

两个关联的实体中的关联对象上,都加上一个 @JsonIgnore 注解,表示在序列化的时候,忽略这个属性(网上有说@ToString(exclude={"userList"})可以规避,但是我没有测试成功,大家可以自己试一下) 如下图所示

@OnetoOne
@JoinColumn(name = "car_id")
@JsonIgnore
private Car car;

三、No class com.example.sbjdemo.pojo.User entity with id 18 exists!

详细报错

org.springframework.dao.EmptyResultDataAccessException: No class com.example.sbjdemo.pojo.User entity with id 18 exists!
	at org.springframework.data.jpa.repository.support.SimpleJpaRepository.lambda$deleteById$0(SimpleJpaRepository.java:173) ~[spring-data-jpa-2.7.10.jar:2.7.10]
	at java.util.Optional.orElseThrow(Optional.java:290) ~[na:1.8.0_212]
	at org.springframework.data.jpa.repository.support.SimpleJpaRepository.deleteById(SimpleJpaRepository.java:172) ~[spring-data-jpa-2.7.10.jar:2.7.10]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_212]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_212]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_212]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_212]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker$RepositoryFragmentMethodInvoker.lambda$new$0(RepositoryMethodInvoker.java:289) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker.doInvoke(RepositoryMethodInvoker.java:137) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker.invoke(RepositoryMethodInvoker.java:121) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryComposition$RepositoryFragments.invoke(RepositoryComposition.java:530) ~[spring-data-commons-2.7.10.jar:2.7.10]

触发场景

执行数据删除操作

错误原因

删除的数据在数据库中不存在

以上就是“Spring JPA错题实例代码分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程之家行业资讯频道。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐