JPA - 多くの関係に多くを使用している間、データがマッピングされたエンティティに保存されたばかりではありません

reiley:

私は、に取り組んでいるJPA私がきたアプリケーション、many-to-many relationship2つのエンティティ間の分隊&製品

Squad.java

import javax.persistence.*;
import java.util.HashSet;
import java.util.Set;

@Entity(name = "SQUAD")
public class Squad extends AuditModel {

    private long id;
    private String name;
    private Set<Product> products = new HashSet<>();

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    @Column(name = "NAME")
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return super.toString();
    }

    @ManyToMany(fetch = FetchType.LAZY,
            cascade = {
                    CascadeType.PERSIST,
                    CascadeType.MERGE
            })
    @JoinTable(name = "SQUAD_PRODUCT",
            joinColumns = {@JoinColumn(name = "SQUAD_ID")},
            inverseJoinColumns = {@JoinColumn(name = "PRODUCT_ID")})
    public Set<Product> getProducts() {
        return products;
    }

    public void setProducts(Set<Product> products) {
        this.products = products;
    }
}

Product.java

import javax.persistence.*;
import java.util.HashSet;
import java.util.Set;

@Entity(name = "PRODUCT")
public class Product extends AuditModel {

    private long id;
    private String name;
    private Set<Squad> squads = new HashSet<>();

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    @Column(name = "NAME")
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @ManyToMany(fetch = FetchType.LAZY,
            cascade = {
                    CascadeType.PERSIST,
                    CascadeType.MERGE
            },
            mappedBy = "products")
    public Set<Squad> getSquads() {
        return squads;
    }

    public void setSquads(Set<Squad> squads) {
        this.squads = squads;
    }
}

私が使用している@RepositoryRestResource基本的な休息コントローラを生成するために(初めて):

SquadRepository.java

@RepositoryRestResource(collectionResourceRel = "squad", path = "squad")
public interface SquadRepository  extends CrudRepository<Squad, Long> {

    List<Squad> findByName(@Param("name") String name);

}

ProductRepository.java

@RepositoryRestResource(collectionResourceRel = "product", path = "product")
public interface ProductRepository extends CrudRepository<Product, Long> {

    List<Product> findByName(@Param("name") String name);

}

今、私はREST呼び出しを使用して分隊にデータを格納します。私は、REST呼び出しの下に使用しているので、私はまた、この分隊内の製品を保存します:

http:// localhost:8080 /チーム

{
    "name": "MyFirstSquad",
    "product": 
        {
            "name": "MyFirstProduct"
        }

}

私が得る応答は次のとおりです。

{
  "createDateTime": "2019-12-15T17:53:37.234",
  "updateDateTime": "2019-12-15T17:53:37.234",
  "name": "MyFirstSquad",
  "_links": {
    "self": {
      "href": "http://localhost:8080/squad/1"
    },
    "squad": {
      "href": "http://localhost:8080/squad/1"
    },
    "products": {
      "href": "http://localhost:8080/squad/1/products"
    }
  }
}

しかし、私が開いたときにhttp:// localhost:8080 /チーム/ 1 /製品は、それが空:

{
  "_embedded" : {
    "product" : [ ]
  },
  "_links" : {
    "self" : {
      "href" : "http://localhost:8080/squad/1/products"
    }
  }
}

任意の提案は、何が私が間違っているのでしょうか?私の残りの呼び出しが正しくない、または、私のコードで不足している何かですか?

感謝

dimirsen:

あなたは、ビューアであなたのDBを視察しましたか?あなたは多対多の関係を使用すると、中間テーブルが作成されます - SQUAD_PRODUCTを。それは数字のペアが含まれています。あなたが製品の番号/ IDを追加することができます前に、ことを意味し、それはテーブルの製品に存在しなければなりません。だから、まず、あなたはPOSTリクエストを経て製品を作成します。第二に、セットに追加するため、その生成されたIDを使用します。私は推測する、それがこの方法を行うことができます。

1st step, POST
{"name": "MyFirstProduct"}

2nd step POST to create squad
{"name": "MyFirstSquad"}

3rd step PATCH created squad (alter it) - request PATCH http://localhost:8080/squad/1 - assuming it was created with id 1
{"name": "MyFirstSquad", "product":["http://localhost:8080/products/1"]} - assuming the product was created with id 1. 

あなたはここにいくつかの製品を一覧表示することができます。それはDBにリストを書き換えすることを、通知をしてください。

私はあなたには、いくつかの修正が必要な場合がありますので、これらのJSONsをチェックする任意の手段を持っていません。

レポ取引で問題がある場合には個人的に、私は、Javaコードで同じ節約をチェックします。

私はFirefoxのプラグインRESTClientをお勧めします。

無関係であるが、私はこれらの行好きではない場合があります。

 private Set<Squad> squads = new HashSet<>();
 private Set<Product> products = new HashSet<>();

彼らは、コレクションをドロップすることがあります。しかし、私は、あまりにも慎重にすることができます:)

おすすめ

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