Hibernate4一对多关系映射

示例:一个类别(Category)下面有多个商品(Product),多个商品对应对应同一类别

 

Java代码   收藏代码
  1. public class Category {  
  2.   
  3.        private Integer id;  
  4.     private String name;  
  5.     private Set<Product> products = new HashSet<Product>();  
  6.   
  7.     // getter and setter  
  8. }     

 

Java代码   收藏代码
  1. public class Product {  
  2.   
  3.     private Integer id;  
  4.     private String name;  
  5.     private Double price;  
  6.     private Category category;  
  7.       
  8.     // getter and setter  
  9. }  

用XML映射

Xml代码   收藏代码
  1. <hibernate-mapping package="org.monday.hibernate4.domain">  
  2.     <class name="Category" table="tbl_category">  
  3.         <id name="id">  
  4.             <generator class="identity" />  
  5.         </id>  
  6.         <property name="name" />  
  7.         <set name="products" inverse="true">  
  8.             <key column="category_id" />  
  9.             <one-to-many class="Product" />  
  10.         </set>  
  11.     </class>  
  12. </hibernate-mapping>  

 

Xml代码   收藏代码
  1. <hibernate-mapping package="org.monday.hibernate4.domain">  
  2.     <class name="Product" table="tbl_product">  
  3.         <id name="id">  
  4.             <generator class="identity" />  
  5.         </id>  
  6.         <property name="name" />  
  7.         <property name="price" />  
  8.         <many-to-one name="category" class="Category"   
  9.             column="category_id" not-null="true"/>  
  10.     </class>  
  11. </hibernate-mapping>  

 用@Annotation映射

Java代码   收藏代码
  1. @Entity  
  2. @Table(name = "tbl_category")  
  3. public class Category {  
  4.   
  5.     @Id  
  6.     @GeneratedValue(strategy = GenerationType.IDENTITY)  
  7.     private Integer id;  
  8.     private String name;  
  9.         // 使用泛型的话,targetEntity可以不制定  
  10.     @OneToMany(mappedBy = "category")  
  11.     private Set<Product> products = new HashSet<Product>();  
  12.   
  13.     // getter and setter      
  14. }     

 

Java代码   收藏代码
  1. @Entity  
  2. @Table(name = "tbl_product")  
  3. public class Product {  
  4.   
  5.     @Id  
  6.     @GeneratedValue(strategy = GenerationType.IDENTITY)  
  7.     private Integer id;  
  8.     private String name;  
  9.     private Double price;  
  10.   
  11.     @ManyToOne  
  12.     @JoinColumn(name = "category_id", nullable = false)  
  13.     private Category category;  
  14.   
  15.     // getter and setter      
  16. }     

 测试代码

Java代码   收藏代码
  1. Product p = new Product();  
  2. p.setName("hibernate");  
  3. p.setPrice(99.9);  
  4.   
  5. Category c = new Category();  
  6. c.setName("book");  
  7. c.getProducts().add(p);  
  8.   
  9. p.setCategory(c);  
  10.   
  11. session.save(c); // 先插入一的一方  
  12. session.save(p);  

  SQL schema

Sql代码   收藏代码
  1. Hibernate:   
  2.     create table tbl_category (  
  3.         id integer not null auto_increment,  
  4.         name varchar(255),  
  5.         primary key (id)  
  6.     )  
  7. Hibernate:   
  8.     create table tbl_product (  
  9.         id integer not null auto_increment,  
  10.         name varchar(255),  
  11.         price double precision,  
  12.         category_id integer,  
  13.         primary key (id)  
  14.     )  
  15. Hibernate:   
  16.     alter table tbl_product   
  17.         add index FK2BA956E5535EE4C (category_id),   
  18.         add constraint FK2BA956E5535EE4C   
  19.         foreign key (category_id)   
  20.         references tbl_category (id)  
  21. Hibernate:   
  22.     insert   
  23.     into  
  24.         tbl_category  
  25.         (name)   
  26.     values  
  27.         (?)  
  28. Hibernate:   
  29.     insert   
  30.     into  
  31.         tbl_product  
  32.         (name, price, category_id)   
  33.     values  
  34.         (?, ?, ?)  
  35.   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值