繁体   English   中英

使用自引用创建 jpa 实体

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM