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.完了,上面的第二点是处理映射关系中的重要内容。
希望可以帮到你,谢谢!