Я новичок в JPA 2.1 и начал использовать только недавно названные диаграммы сущностей. Для моего проекта я сопоставляю следующее соотношение в JPA 2.1:
Заказ → OrderDetail → Продукт → ProductLine
Вопрос:
Я хочу проинструктировать JPA присоединиться и правильно получить все необходимые данные. До сих пор это безупречно работает для Order → OrderDetail → Product, но до сих пор мне не удалось добавить Sub-Sub Graph для того, чтобы идти так же глубоко, как класс ProductLine. Как сделать подграф подграфа? Ex получают ProductLine продукта?
Вот мои сущности (пропущенные геттеры и сеттеры):
Order
@Entity
@Table(name="ORDERS")
@NamedEntityGraph(
name = "graph.Order.details",
attributeNodes = {
@NamedAttributeNode(value = "details", subgraph = "graph.OrderDetail.product")
},
subgraphs = {
@NamedSubgraph(name = "graph.OrderDetail.product", attributeNodes = @NamedAttributeNode("product"))
}
)
public class Order implements Serializable{
@Id
@Column(name = "orderNumber")
private Long number;
@Column(name = "orderDate")
private Date date;
@OneToMany(mappedBy = "order")
private List<OrderDetail> details;
}
OrderDetail
@Entity
@Table(name = "orderdetails")
public class OrderDetail implements Serializable{
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "orderNumber")
@Id
private Order order;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "productCode", nullable = false)
@Id
private Product product;
@Column(name = "orderLineNumber")
private int lineNumber;
@Column(name = "quantityOrdered")
private int quantity;
продукт
@Entity
@Table(name = "products")
class Product {
@Column(name = "productCode")
@Id
private String code;
@Column(name = "quantityInStock")
public int quantity;
@ManyToOne
@JoinColumn(name = "productLine")
private ProductLine line;
ProductLine
@Entity
@Table(name = "productlines")
public class ProductLine {
@Id
@Column(name = "productLine")
private String line;
@Column
private String textDescription;