@ManyToOneとエラー - JPA / Hibernateは独立したエンティティが永続する渡されます

iamtravisw:

こんばんは、

私は、Hibernateを使用するための比較的新しいですし、私は次のようなエラーに実行しています:

"message": "org.springframework.web.util.NestedServletException: Request processing failed; 
nested exception is org.springframework.dao.InvalidDataAccessApiUsageException: detached entity passed to persist: 
com.company.project.data.relational.models.ListsItems; nested exception is org.hibernate.PersistentObjectException: 
detached entity passed to persist: com.company.project.data.relational.models.ListsItems",

私は、ネストされたオブジェクトを持っているフロントエンドから送信されるJSONオブジェクトを持っています。私は、元のオブジェクトのIDを使用しての関係で、MySQLでの別のテーブルにネストされたアイテムを取得しようとしています。

ここではJSONの例を示します。

{
    "name":"Test",
    "type":"App Id List",
    "listItems":
    [
        {
            "id":1,
            "name":"Test",
            "value":" 1"
        },
        {
            "id":2,
            "name":"NEW TEST",
            "value":" 2"
        }
    ]
}

ここに私のリストモデルは次のとおりです。

@Entity
@Getter
@Setter
@NoArgsConstructor
@Table(name = "lists")
public class Lists implements Serializable, OperationalEntity {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long id;

    @Column(columnDefinition = "char", nullable = false)
    private String guid;
    private String name;
    private String type;

    @OneToMany(fetch = FetchType.EAGER, mappedBy = "listItems", orphanRemoval = true)
    @Cascade({org.hibernate.annotations.CascadeType.ALL, })
    private Set<ListsItems> listItems;

    private Date created;
    private Date updated;

}

そして、ここに私のListsItemsモデルは次のとおりです。

@Getter
@Setter
@Entity
@Table(name = "lists_items")
@NoArgsConstructor
public class ListsItems implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long id;

    private String name;
    private String value;

    @NaturalId
    @ManyToOne(optional = false, fetch = FetchType.EAGER)
    @JoinColumn(name = "lists_id", referencedColumnName = "id")
    private Lists listItems;

}

ここでセーブ機能です。

@PostMapping(value = "/add")
    @PreAuthorize("hasRole('ADMIN')")
    public @ResponseBody WebResponse<W> create(@RequestBody W webModel) {
        D dbModel = asDbModel(webModel);
        dbModel.setGuid(UUID.randomUUID().toString());
        return WebResponse.success(createWebModelFromDbModel(getDatabaseEntityRepository().save(dbModel)));
    }

このエラーの原因となるかもしれないもの上の任意のアイデア?私は少しを検索したが、私は他のソリューションから試してみた何も働いていません。

前もって感謝します!
-トラヴィスW.

iamtravisw:

答えは、リストアイテムに次の変更を作ることでした。

    @JsonIgnore // this import will be from jackson
    @NaturalId
    @ManyToOne(optional = false, fetch = FetchType.LAZY)
    @JoinColumn(name = "lists_id", referencedColumnName = "id")
    private Lists list;

そして、リストに次の:

@OneToMany(fetch = FetchType.EAGER, mappedBy = "list", orphanRemoval = true)
    @Cascade({org.hibernate.annotations.CascadeType.ALL, })
    private Set<ListsItems> listItems;

また、私は結果を反復処理するために必要な:

@Override
    protected Lists asDbModel(WebLists webModel) {
        Lists dbModel = new Lists();
        dbModel.setId(webModel.getId());
        dbModel.setName(webModel.getName());
        dbModel.setType(webModel.getType());
        dbModel.setListItems(webModel.getListItems());
        for(ListsItems item : webModel.getListItems()) {
            item.setList(dbModel);
        }
        return dbModel;

    }

おすすめ

転載: http://43.154.161.224:23101/article/api/json?id=277410&siteId=1