![](/img/trans.png)
[英]Spring JPA Entity Graph and Self Reference occur N+1 query
[英]Creating jpa entity with self reference
我有需要通过一对一映射自我引用的 pojo。 我正在使用flyway来调出桌子。 该应用程序启动正常,但是当我尝试执行获取请求时,我收到以下错误:
nested exception is com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Direct self-reference leading to cycle
我认为我自我引用的方式有问题。 请帮忙。 提前致谢。
这是我的 sql:
CREATE TABLE tbl_person (
id BIGINT(20) NOT NULL AUTO_INCREMENT,
name VARCHAR(255),
parent_id BIGINT(20),
primary key (id));
CREATE SEQUENCE person_seq START WITH 1 INCREMENT BY 1;
这是我的 model:
@Entity
@Data
@Table(name="tbl_person")
public class Person {
@Id
@GeneratedValue(strategy= GenerationType.SEQUENCE,generator = "person_seq")
@SequenceGenerator(name="person_seq",allocationSize = 1)
@Column(name="id",insertable =false,nullable = false,updatable = false)
private Long id;
@Column(name="name")
private String name;
@Column(name="address")
private String address
@OneToOne
@JoinColumn(name="parent_id")
@JsonManagedReference
private Person person;
}
错误信息来自 jackson。 因此,它在转换为 java object 或返回 json/xml 时失败,而不是将其写入数据库。
问题是生成的 JSON object 可能包含另一个 Person-json 可以指同一个人。 这将创建一个无限循环。
这会导致这样的事情:
{
"id": 1,
"name": "Example",
"address": "example-address",
"person": {
"id": 1,
"name": "Example",
"address": "example-address",
"person": {
"id": 1,
"name": "Example",
"address": "example-address",
"person": {
...
}
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.