JPA 一对多实例配置
2010-01-05 17:10
155 查看
xml代码
在JPA中双向一对多关系则多方为关系护端即负责外键记录的更新,一方为被维护端即没有权力更新外键记录
src下在面的META-INF/persistence.xml配置如下:
订单和订单项两个实例实体Bean如下:
订单表:
订单项表:
测试:
1、hibernate是双向的,通过one可以找到many,通过many可以找到one,
要想找到对方,必须将对方作为当前对象属性,在one这边
应当有一个Set属性装载多many对象,在many这边应当有一个
属性装载一个One对象。
public class customer
{
private Set buies;
private String customerName;
public void setBuies(Set buies)
{
this.buies=buies;
}
public Set getBuies()
{
return this.buies;
}
}
public class Buy
{
private Integer buyID;
private Customer customer;
public void setCustomer(Customer customer)
{
this.customer=customer;
}
public Customer getCustomer()
{
return this.customer;
}
}
2、主控方:维护外键列的值。
1、inverse="false"代表是主控方,另一方便是被控方,
反之inverse="true"代表是被控方,另一方便是主控方。
要想维护外键的值,必须将被控方作为主控方的属性。
一般主控方要many这边,不在one那边。
3、延迟加载:
1、lazy="true"代表是延迟加载,加载时只加载当前对象的,
不加载其关联对象的值,只有取关联对象的值时才执行sql
加载对方。
2、lazy="false"代表即时加载,加载时不但加载当前对象的,
还加载其关联的所有对象信息。
4、级联处理:主增从增、主删从删、从改从改,要做到该功能,必须将
从作为主的一个属性或主集合属性中的一个元素。
1、cascade="all" 代表级联insert、update、delete操作
2、cascade="save-update" 代表级联insert、update操作
主键的生成方式:
1、必须手动给定主键值
assigned
2、用户及hibernate都不管由数据库生,如identity
native
1、html:select标签
2、过滤器
1、filter
2、RequestProcessor
<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="mengya" transaction-type="RESOURCE_LOCAL"> <properties> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/> <property name="hibernate.hbm2ddl.auto" value="update"/> <property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver"/> <property name="hibernate.connection.username" value="root"/> <property name="hibernate.connection.password" value="123"/> <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/mp?useUnicode=true&characterEncoding=UTF-8"/> </properties> </persistence-unit> </persistence>
在JPA中双向一对多关系则多方为关系护端即负责外键记录的更新,一方为被维护端即没有权力更新外键记录
src下在面的META-INF/persistence.xml配置如下:
订单和订单项两个实例实体Bean如下:
订单表:
package com.mengya.bean; import java.util.HashSet; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.Id; import javax.persistence.OneToMany; import javax.persistence.Table; @Entity @Table(name = "orders") public class Order { private String orderId; private Float amount = 0f;// 设置默认值 private Set<OrderItem> items = new HashSet<OrderItem>(); @Id @Column(length = 32) public String getOrderId() { return orderId; } public void setOrderId(String orderId) { this.orderId = orderId; } @Column(nullable = false) public Float getAmount() { return amount; } public void setAmount(Float amount) { this.amount = amount; } // cascade表示级联操作 // CascadeType.MERGE级联更新:若items属性修改了那么order对象保存时同时修改items里的对象。对应EntityManager的merge方法 // CascadeType.PERSIST级联刷新:获取order对象里也同时也重新获取最新的items时的对象。对应EntityManager的refresh(object)方法有效。即会重新查询数据库里的最新数据 // CascadeType.REFRESH级联保存:对order对象保存时也对items里的对象也会保存。对应EntityManager的presist方法 // CascadeType.REMOVE级联删除:对order对象删除也对items里的对象也会删除。对应EntityManager的remove方法 // FetchType.LAZY表示懒加载。对于xxxtoMany时即获得多的一方fetch的默认值是FetchType.LAZY懒加载。对于xxxtoOne时即获得一的一方fetch的默认值是FetchType.EAGER立即加载 // mappedBy表示关系统被维护端,它的值是关系维护端维护关系的属性 @OneToMany(cascade = { CascadeType.PERSIST, CascadeType.REFRESH, CascadeType.REMOVE }, fetch = FetchType.LAZY, mappedBy = "order") public Set<OrderItem> getItems() { return items; } public void setItems(Set<OrderItem> items) { this.items = items; } /** * 自己的加的一个方法,为了方便添加OrderItem * */ public void addOrderItem(OrderItem item) { item.setOrder(this); this.items.add(item); } }
订单项表:
package com.mengya.bean; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; @Entity public class OrderItem { private Integer id; private String productName; private Float sellPrice = 0f;// 设置默认值 private Order order; @Id @GeneratedValue(strategy = GenerationType.AUTO) public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } @Column(length = 40, nullable = false) public String getProductName() { return productName; } public void setProductName(String productName) { this.productName = productName; } @Column(nullable = false) public Float getSellPrice() { return sellPrice; } public void setSellPrice(Float sellPrice) { this.sellPrice = sellPrice; } // cascade表示级联。CascadeType.REFRESH级联刷新 // optional表示该对象可有可无,它的值为true表示该外键可以为null,它的值为false表示该外键为not null @ManyToOne(cascade = CascadeType.REFRESH, fetch = FetchType.EAGER, optional = false) // JoinColumn表示外键的列 @JoinColumn(name="orderId") public Order getOrder() { return order; } public void setOrder(Order order) { this.order = order; } }
测试:
package com.mengya.junit.test; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; import org.junit.Test; import com.mengya.bean.Order; import com.mengya.bean.OrderItem; public class JPA_OnetoManyTest { @Test public void save(){ EntityManagerFactory factory=Persistence.createEntityManagerFactory("mengya"); EntityManager em=factory.createEntityManager(); em.getTransaction().begin(); Order order=new Order(); order.setOrderId("200910120001"); order.setAmount(450f); OrderItem item1=new OrderItem(); item1.setProductName("篮球"); item1.setSellPrice(220f); OrderItem item2=new OrderItem(); item2.setProductName("排球"); item2.setSellPrice(230f); order.addOrderItem(item1); order.addOrderItem(item2); em.persist(order); em.getTransaction().commit(); em.close(); factory.close(); } }
1、hibernate是双向的,通过one可以找到many,通过many可以找到one,
要想找到对方,必须将对方作为当前对象属性,在one这边
应当有一个Set属性装载多many对象,在many这边应当有一个
属性装载一个One对象。
public class customer
{
private Set buies;
private String customerName;
public void setBuies(Set buies)
{
this.buies=buies;
}
public Set getBuies()
{
return this.buies;
}
}
public class Buy
{
private Integer buyID;
private Customer customer;
public void setCustomer(Customer customer)
{
this.customer=customer;
}
public Customer getCustomer()
{
return this.customer;
}
}
2、主控方:维护外键列的值。
1、inverse="false"代表是主控方,另一方便是被控方,
反之inverse="true"代表是被控方,另一方便是主控方。
要想维护外键的值,必须将被控方作为主控方的属性。
一般主控方要many这边,不在one那边。
3、延迟加载:
1、lazy="true"代表是延迟加载,加载时只加载当前对象的,
不加载其关联对象的值,只有取关联对象的值时才执行sql
加载对方。
2、lazy="false"代表即时加载,加载时不但加载当前对象的,
还加载其关联的所有对象信息。
4、级联处理:主增从增、主删从删、从改从改,要做到该功能,必须将
从作为主的一个属性或主集合属性中的一个元素。
1、cascade="all" 代表级联insert、update、delete操作
2、cascade="save-update" 代表级联insert、update操作
主键的生成方式:
1、必须手动给定主键值
assigned
2、用户及hibernate都不管由数据库生,如identity
native
1、html:select标签
2、过滤器
1、filter
2、RequestProcessor
相关文章推荐
- JPA多对多@manytomany注解配置实例
- spring jpa 的配置及使用实例
- Maven + JPA + Hibernate + Postgresql的基本配置实例
- JPA 多对多实例配置
- Nginx负载均衡配置实例详解
- JPA的配置文件persistence.xml参数详解
- Spring的开发配置与Spring中bean的实例化
- JPA2.0和Spring的集成配置方式
- 一个关于通过ACL禁用ICMP的实例配置
- spring data jpa 配置
- java中配置JPA方法
- DNS配置实例
- Hibernate学习--JPA配置文件persistence.xml解析
- java配置spring-data-jpa持久化
- Struts 2 自学之路: 3.1 struts.xml 核心配置实例说明
- Tomcat 多实例配置
- 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL
- [Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例二.
- S3c2440ALCD控制器配置实例