Spring JPA 錯(cuò)題集解決案例
一、No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor
詳細(xì)報(bào)錯(cuò)
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] ...........
觸發(fā)場(chǎng)景
當(dāng)fetch設(shè)置為懶加載的時(shí)候(fetch = FetchType.LAZY
),進(jìn)行查詢操作
錯(cuò)誤原因
car在轉(zhuǎn)化為json的時(shí)候,序列化失敗了(大概就是這個(gè)意思吧)
解決辦法
在序列化失敗的實(shí)體類上添加 @JsonIgnoreProperties(value = {"hibernateLazyInitializer"})
二、java.lang.StackOverflowError: null
詳細(xì)報(bào)錯(cuò)
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]
觸發(fā)場(chǎng)景
兩個(gè)關(guān)聯(lián)的實(shí)體類都有外鍵字段,且都有關(guān)聯(lián)注解,如:@OneToOne、@OneToManay、@ManyToOne、@ManyToMany
錯(cuò)誤原因
兩個(gè)相關(guān)聯(lián)的對(duì)象互相調(diào)用并打印,形成一個(gè)遞歸調(diào)用,最后堆棧溢出
解決辦法
兩個(gè)關(guān)聯(lián)的實(shí)體中的關(guān)聯(lián)對(duì)象上,都加上一個(gè) @JsonIgnore 注解,表示在序列化的時(shí)候,忽略這個(gè)屬性(網(wǎng)上有說(shuō)@ToString(exclude={"userList"})
可以規(guī)避,但是我沒(méi)有測(cè)試成功,大家可以自己試一下) 如下圖所示
@OneToOne @JoinColumn(name = "car_id") @JsonIgnore private Car car;
三、No class com.example.sbjdemo.pojo.User entity with id 18 exists!
詳細(xì)報(bào)錯(cuò)
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]
觸發(fā)場(chǎng)景
執(zhí)行數(shù)據(jù)刪除操作
錯(cuò)誤原因
刪除的數(shù)據(jù)在數(shù)據(jù)庫(kù)中不存在
以上就是Spring JPA 錯(cuò)題集解決案例的詳細(xì)內(nèi)容,更多關(guān)于Spring JPA 錯(cuò)題集的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java優(yōu)先隊(duì)列PriorityQueue中Comparator的用法詳解
這篇文章主要介紹了java優(yōu)先隊(duì)列PriorityQueue中Comparator的用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Java基于正則表達(dá)式實(shí)現(xiàn)的替換匹配文本功能【經(jīng)典實(shí)例】
這篇文章主要介紹了Java基于正則表達(dá)式實(shí)現(xiàn)的替換匹配文本功能,結(jié)合完整實(shí)例形式分析了java字符串正則替換操作技巧,需要的朋友可以參考下2017-04-04Java JDK動(dòng)態(tài)代理實(shí)現(xiàn)原理實(shí)例解析
這篇文章主要介紹了Java JDK動(dòng)態(tài)代理實(shí)現(xiàn)原理實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06SpringBoot+MyBatisPlus+Vue 前后端分離項(xiàng)目快速搭建過(guò)程(前端篇)
這篇文章主要介紹了SpringBoot+MyBatisPlus+Vue 前后端分離項(xiàng)目快速搭建過(guò)程(前端篇),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05Java 是如何利用接口避免函數(shù)回調(diào)的方法
本篇文章主要介紹了Java 是如何利用接口避免函數(shù)回調(diào)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02舉例講解Java的Hibernate框架中的多對(duì)一和一對(duì)多映射
這篇文章主要介紹了Java的Hibernate框架中的多對(duì)一和一對(duì)多映射,Hibernate是Java的SSH三大web開(kāi)發(fā)框架之一,需要的朋友可以參考下2015-12-12Spring?boot?運(yùn)用策略模式實(shí)現(xiàn)避免多次使用if
這篇文章主要介紹了Spring?boot?運(yùn)用策略模式實(shí)現(xiàn)避免多次使用if,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09java并發(fā)編程專題(二)----如何創(chuàng)建并運(yùn)行java線程
這篇文章主要介紹了java并發(fā)編程如何創(chuàng)建并運(yùn)行java線程,文中講解非常詳細(xì),示例代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-06-06