我是靠谱客的博主 玩命羊,最近开发中收集的这篇文章主要介绍java 多对多_java-多对多表中的多对多,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

我有一个包含产品列表的表订单.对于与特定订单相对应的每个产品,我需要存储一个地址列表,在该地址中应将单个产品(每个订单基于每个产品)发送到

+----------------+------------+

| Order_ID | Product_ID |

+----------------+------------+

| 1 | 1000 |

| 2 | 1000 |

| 2 | 1001 |

+----------------+------------+

因此,我有这张表,其中有很多关于订单和产品的表格,我需要将上表中的每个条目映射到地址列表.所以我需要像

|PK|Order_ID |Product_ID |

| 1| 1 | 1000 |

| 2| 2 | 1000 |

| 3| 2 | 1001 |

并将上表中的条目映射到地址列表,我需要上述PK和地址ID(我的地址表的主键)上的多对多表

|PK_Order_Product |Address_ID|

| 1 | 1 |

| 2 | 1 |

| 2 | 3 |

这里PK_Order_Product是上一张表的主键(PK)上的外键

我正在使用JPA保留到我的MYSQL数据库中,如果我的设计正确,请帮助我提供一个代码片段.如何使用JPA注释在Java中做到这一点

解决方法:

这实际上是一个好问题,值得一些研究和试验.有许多方法可以进行映射.提出更好的设计实际上取决于您的应用程序需求.但是我认为这是实现映射的有效方法:

我将为订单,产品和地址有3个单独的实体.

我们将不会在订单和产品这两个实体之间实现通常的多对多关系,在这两个实体的每一侧都有彼此的集合.相反,我将创建另一个实体来表示Order和Product之间的关系,并将其命名为ProductOrder.它们的关系映射如下:

>订单与ProductOrder具有一对多关系.

> ProductOrder与Order具有多对一关系.

>产品与ProductOrder具有一对多关系.

> ProductOrder与Product具有多对一关系.

ProductOrder的主键将由Order的主键和Product的主键组成-因此这将是一个复合键.因此,我们将需要使用@IdClass映射复合键.

现在,这是在多对多关系中实现多对多的窍门:

ProductOrder与Address具有多对多关系.

请参阅上述每个实体的示例代码:

订单实体

@Entity

@Table(name = "ORDERS")

public class Order {

@Id

@GeneratedValue(strategy = GenerationType.IDENTITY)

@Column(name = "ORDER_ID")

private Long id;

private int quantity;

@OneToMany(mappedBy = "order")

private List productOrderList = new ArrayList();

...

}

产品实体

@Entity

@Table(name="PRODUCT")

public class Product {

@Id

@GeneratedValue(strategy = GenerationType.IDENTITY)

@Column(name = "PRODUCT_ID")

private Long id;

private String name;

@OneToMany(mappedBy = "product")

private List productOrderList = new ArrayList();

...

}

地址实体

@Entity

@Table(name="ADDRESS")

public class Address {

@Id

@GeneratedValue(strategy = GenerationType.IDENTITY)

@Column(name = "ADDRESS_ID")

private Long id;

private String state;

@ManyToMany(mappedBy = "addressList")

private List productOrderList = new ArrayList();

...

}

生产者实体

@Entity

@Table(name="PRODUCT_ORDER")

@IdClass(ProductOrderId.class)

public class ProductOrder {

@Id

@ManyToOne

@JoinColumn(name="ORDER_ID")

private Order order;

@Id

@ManyToOne

@JoinColumn(name="PRODUCT_ID")

private Product product;

@ManyToMany

@JoinTable(name="PRODUCT_ORDER_ADDRESS",

joinColumns={@JoinColumn(name="ORDER_ID", referencedColumnName="ORDER_ID"),

@JoinColumn(name="PRODUCT_ID", referencedColumnName="PRODUCT_ID")},

inverseJoinColumns=@JoinColumn(name="ADDRESS_ID", referencedColumnName="ADDRESS_ID"))

private List

addressList = new ArrayList
();

...

}

ProductOrder实体的@IdClass

public class ProductOrderId {

private Long order;

private Long product;

...

}

以下是用于创建实体并将其持久化的示例代码:

EntityManager em = emf.createEntityManager();

em.getTransaction().begin();

Order order = new Order();

order.setQuantity(10);

em.persist(order);

Product product = new Product();

product.setName("Coffee");

em.persist(product);

Address address = new Address();

address.setState("CA");

em.persist(address);

ProductOrder productOrder = new ProductOrder();

productOrder.setOrder(order);

productOrder.setProduct(product);

productOrder.getAddressList().add(address);

address.getProductOrderList().add(productOrder);

em.persist(productOrder);

em.getTransaction().commit();

这是在MySQL数据库中生成模式的方式:

Hibernate:

create table ADDRESS (

ADDRESS_ID bigint not null auto_increment,

state varchar(255),

primary key (ADDRESS_ID)

)

Hibernate:

create table ORDERS (

ORDER_ID bigint not null auto_increment,

quantity integer not null,

primary key (ORDER_ID)

)

Hibernate:

create table PRODUCT (

PRODUCT_ID bigint not null auto_increment,

name varchar(255),

primary key (PRODUCT_ID)

)

Hibernate:

create table PRODUCT_ORDER (

ORDER_ID bigint,

PRODUCT_ID bigint,

primary key (ORDER_ID, PRODUCT_ID)

)

Hibernate:

create table PRODUCT_ORDER_ADDRESS (

ORDER_ID bigint not null,

PRODUCT_ID bigint not null,

ADDRESS_ID bigint not null

)

Hibernate:

alter table PRODUCT_ORDER

add constraint FK_sl39bwx60xjbvoiujpaes74ty

foreign key (ORDER_ID)

references ORDERS (ORDER_ID)

Hibernate:

alter table PRODUCT_ORDER

add constraint FK_n0i7uxq6rxsc0mcred1cds4m9

foreign key (PRODUCT_ID)

references PRODUCT (PRODUCT_ID)

Hibernate:

alter table PRODUCT_ORDER_ADDRESS

add constraint FK_kad6crei9lgrv1nuuuff42vs8

foreign key (ADDRESS_ID)

references ADDRESS (ADDRESS_ID)

Hibernate:

alter table PRODUCT_ORDER_ADDRESS

add constraint FK_hpx0e467dvpqi5i6kxmujns2b

foreign key (ORDER_ID, PRODUCT_ID)

references PRODUCT_ORDER (ORDER_ID, PRODUCT_ID)

标签:java,mysql,jpa,hibernate,many-to-many

来源: https://codeday.me/bug/20191009/1880330.html

最后

以上就是玩命羊为你收集整理的java 多对多_java-多对多表中的多对多的全部内容,希望文章能够帮你解决java 多对多_java-多对多表中的多对多所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部