Spring JPA 错题集解决案例

作者:烟雨戏江南 时间:2022-03-26 22:44:03 

一、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]

触发场景

执行数据删除操作

错误原因

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

来源:https://juejin.cn/post/7225148494620147773/

标签:Spring,JPA,错题集
0
投稿

猜你喜欢

  • Flutter实现抽屉动画

    2023-06-18 01:49:19
  • 一文搞懂Spring中的注解与反射

    2023-11-11 11:38:18
  • Java的动态分派和静态分派的实现

    2023-10-09 12:58:37
  • SpringBoot结合Redis配置工具类实现动态切换库

    2022-04-15 14:14:13
  • MyBatis注解CRUD与执行流程深入探究

    2023-07-03 06:19:44
  • Springcloud seata分布式事务实现代码解析

    2022-12-27 20:14:01
  • SpringBoot实现Mysql使用MD5进行密码加密的示例

    2022-11-24 23:14:16
  • Java SpringBoot自动装配原理详解

    2022-09-08 01:15:09
  • mybatisPlus返回Map类型的集合

    2022-01-31 13:37:07
  • 详解关于SpringBoot的外部化配置使用记录

    2023-08-10 03:54:54
  • RocketMQ4.5.2 修改mqnamesrv 和 mqbroker的日志路径操作

    2023-11-28 14:03:18
  • 解决idea spring boot 修改html等不重启即时生效的问题

    2023-11-13 18:37:47
  • 安卓GreenDao框架一些进阶用法整理

    2023-06-17 03:27:21
  • Java求两集合中元素交集的四种方法对比分析

    2023-08-23 09:24:56
  • Spring Boot启动过程全面解析(三)

    2023-09-13 13:16:39
  • Java中静态代码块、构造代码块、构造函数和普通代码块的区别

    2023-11-25 10:09:06
  • java.text.DecimalFormat用法详解

    2022-09-30 03:02:27
  • 深入分析JAVA 建造者模式

    2023-03-14 01:32:27
  • Java实现图片验证码具体代码

    2021-06-30 13:16:35
  • Java与Node.js利用AES加密解密出相同结果的方法示例

    2021-09-11 21:06:58
  • asp之家 软件编程 m.aspxhome.com