私は、に取り組んでいるJPA
私がきたアプリケーション、many-to-many relationship
2つのエンティティ間の分隊&製品。
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呼び出しの下に使用しているので、私はまた、この分隊内の製品を保存します:
{
"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"
}
}
}
任意の提案は、何が私が間違っているのでしょうか?私の残りの呼び出しが正しくない、または、私のコードで不足している何かですか?
感謝
あなたは、ビューアであなたの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<>();
彼らは、コレクションをドロップすることがあります。しかし、私は、あまりにも慎重にすることができます:)