使用JPA的建立一对多关系

1、persistence.xml文件
</pre><pre name="code" class="html">数据库使用oracle
<?xml version="1.0" encoding="UTF-8"?>  
<persistence xmlns="http://java.sun.com/xml/ns/persistence" 
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
 http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" 
 version="1.0"> 

 <persistence-unit name="jpa" transaction-type="RESOURCE_LOCAL"> 
	 <properties> 
	 	<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" /> 
	
	 	<property name="hibernate.connection.driver_class" value="oracle.jdbc.driver.OracleDriver" /> 
	 	<property name="hibernate.connection.username" value=" " /> 
	 	<property name="hibernate.connection.password" value=" " /> 
	 	<property name="hibernate.connection.url" value="jdbc:oracle:thin:@xxx.xxx.xxx.xxx:1521:xxxx" /> 
	 	<property name="hibernate.max_fetch_depth" value="5" /> 
	 	<property name="hibernate.jdbc.fetch_size" value="20" /> 
	 	<property name="hibernate.jdbc.batch_size" value="10" /> 
	
	 	<property name="hibernate.hbm2ddl.auto" value="update" /> 
	 	<property name="hibernate.show_sql" value="true" /> 
	 	<property name="hibernate.format_sql" value="false" /> 
	 </properties> 
 </persistence-unit> 
</persistence>

2、订单类

package entity.oneToMany;

import java.util.HashSet;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import org.hibernate.annotations.GenericGenerator;
@Entity
@Table(name="myorders")
public class Order {
	
	private Integer id;
	private String orderId;
	private Float total;
	
	private Set<OrderItem> items=new HashSet<OrderItem>();
	
	
	
	@Id @GeneratedValue
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getOrderId() {
		return orderId;
	}
	public void setOrderId(String orderId) {
		this.orderId = orderId;
	}
	@Column(nullable=false)
	public Float getTotal() {
		return total;
	}
	public void setTotal(Float total) {
		this.total = total;
	}
	//关系被维护端
	@OneToMany(cascade=CascadeType.ALL,mappedBy="order")
	public Set<OrderItem> getItems() {
		return items;
	}
	public void setItems(Set<OrderItem> items) {
		this.items = items;
	}
	
	/*public void add(OrderItem o){
		this.items.add(o);
	}*/
}

3、订单项

package entity.oneToMany;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity
@Table(name="myorderItem")
public class OrderItem {
	
	private Integer id;
	private String productName;
	private Float sellPrice;
	
	private Order order;
	
	@Id @GeneratedValue
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	@Column(nullable=false)
	public String getProductName() {
		return productName;
	}
	public void setProductName(String productName) {
		this.productName = productName;
	}
	public Float getSellPrice() {
		return sellPrice;
	}
	public void setSellPrice(Float sellPrice) {
		this.sellPrice = sellPrice;
	}
	//关系维护端  设置外键
	@ManyToOne(cascade={CascadeType.REFRESH,CascadeType.MERGE},optional=false)
	@JoinColumn(name="order_id")
	public Order getOrder() {
		return order;
	}
	public void setOrder(Order order) {
		this.order = order;
	}
	
}
4 测试类里的测试方式:

<span style="white-space:pre">	</span>@Test
	public void save(){
		EntityManagerFactory factory = Persistence.createEntityManagerFactory("jpa");
		EntityManager em = factory.createEntityManager();
		//System.out.println(em);
		EntityTransaction transaction = em.getTransaction();
		transaction.begin();
		
		Order order = new Order();
		
		OrderItem orderItem1 = new OrderItem();
		orderItem1.setProductName("羽毛球");
		orderItem1.setSellPrice(45f);
		orderItem1.setOrder(order);
		
		OrderItem orderItem2 = new OrderItem();
		orderItem2.setProductName("篮球球");
		orderItem2.setSellPrice(95f);
		orderItem2.setOrder(order);
		
		Set<OrderItem> items=new HashSet<OrderItem>();
		items.add(orderItem2);
		items.add(orderItem1);
		
		order.setOrderId("20151201123");
		order.setTotal(100f);
		order.setItems(items);
		
		em.persist(order);
		
		transaction.commit();
		em.close();
		factory.close();
		//System.out.println(factory);
	}

总结:

1、在处理一对多关系时,通常都是"多"的一方作为关系维护端,"一"的一方为关系被维护端;(黎活明老师提的观点)

2、最重要的注解如何写呢?

完成以下几件事即可:

a.关系维护端(即多的一方)在关联属性的get方法上加@ManyToOne注解,并设置cascade级联、optional=false;

如:@ManyToOne(cascade={CascadeType.REFRESH,CascadeType.MERGE},optional=false)

b.关系维护端(即多的一方)在关联属性的get方法上加@JoinColumn注解,并设置外键名称,

如@JoinColumn(name="order_id")

c.关系被维护端(即“一”的一方),在关联的属性的get方法上加@OneToMany注解,并设置cascade级联、mappedBy属性(多的一方的那个字段名)

如:@OneToMany(cascade=CascadeType.ALL,mappedBy="order")

3.完了,上面的第二点是处理映射关系中的重要内容。


希望可以帮到你,谢谢!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值