Hibernate,JPA注解@OneToMany_Map

用例代码如下:

  • 数据库DDL语句

1,CAT表

 1 create table CAT
 2 (
 3   id          VARCHAR2(32 CHAR) not null,
 4   create_time TIMESTAMP(6),
 5   update_time TIMESTAMP(6),
 6   cat_name    VARCHAR2(255 CHAR),
 7   first_name  VARCHAR2(255 CHAR),
 8   last_name   VARCHAR2(255 CHAR),
 9   version     NUMBER(10) not null
10 )

2,HOBBY表

1 create table HOBBY
2 (
3   id          VARCHAR2(32 CHAR) not null,
4   create_time TIMESTAMP(6),
5   update_time TIMESTAMP(6),
6   name        VARCHAR2(255 CHAR),
7   cat_id      VARCHAR2(32 CHAR)
8 )
  • hibernate.cfg.xml
 1 <?xml version="1.0" encoding="utf-8" ?>
 2 <!DOCTYPE hibernate-configuration
 3  PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
 4  "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
 5 <hibernate-configuration>
 6     <session-factory>
 7         <!-- 数据库驱动配置 -->
 8         <property name="dialect">org.hibernate.dialect.Oracle10gDialect</property>
 9         <property name="connection.driver_class">oracle.jdbc.OracleDriver</property>
10         <property name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:orcl</property>
11         <property name="connection.username">wxuatuser</property>
12         <property name="connection.password">xlh</property>
13         <property name="show_sql">true</property>
14         <!-- 自动执行DDL属性是update,不是true -->
15         <property name="hbm2ddl.auto">update</property>
16         <!-- hibernate实体类 -->
17
18         <mapping class="b10_OneToMany_Map.Cat"/>
19         <mapping class="b10_OneToMany_Map.Hobby"/>
20
21     </session-factory>
22 </hibernate-configuration>
  • java类

实体类 - 基类

 1 package model;
 2 import java.io.Serializable;
 3 import java.util.Date;
 4 import javax.persistence.Column;
 5 import javax.persistence.GeneratedValue;
 6 import javax.persistence.Id;
 7 import javax.persistence.MappedSuperclass;
 8 import org.hibernate.annotations.GenericGenerator;
 9 /**
10  * 实体类 - 基类
11  */
12 @MappedSuperclass
13 public class BaseEntity implements Serializable {
14
15     private static final long serialVersionUID = -6718838800112233445L;
16
17     private String id;// ID
18     private Date create_time;// 创建日期
19     private Date update_time;// 修改日期
20     @Id
21     @Column(length = 32, nullable = true)
22     @GeneratedValue(generator = "uuid")
23     @GenericGenerator(name = "uuid", strategy = "uuid")
24     public String getId() {
25         return id;
26     }
27     public void setId(String id) {
28         this.id = id;
29     }
30     @Column(updatable = false)
31     public Date getCreate_time() {
32         return create_time;
33     }
34     public void setCreate_time(Date create_time) {
35         this.create_time = create_time;
36     }
37     public Date getUpdate_time() {
38         return update_time;
39     }
40     public void setUpdate_time(Date update_time) {
41         this.update_time = update_time;
42     }
43     @Override
44     public int hashCode() {
45         return id == null ? System.identityHashCode(this) : id.hashCode();
46     }
47     @Override
48     public boolean equals(Object obj) {
49         if (this == obj) {
50             return true;
51         }
52         if (obj == null) {
53             return false;
54         }
55         if (getClass().getPackage() != obj.getClass().getPackage()) {
56             return false;
57         }
58         final BaseEntity other = (BaseEntity) obj;
59         if (id == null) {
60             if (other.getId() != null) {
61                 return false;
62             }
63         } else if (!id.equals(other.getId())) {
64             return false;
65         }
66         return true;
67     }
68 }

实体类

Cat.java

 1 package b10_OneToMany_Map;
 2 import java.util.Map;
 3 import javax.persistence.AttributeOverride;
 4 import javax.persistence.AttributeOverrides;
 5 import javax.persistence.CascadeType;
 6 import javax.persistence.Column;
 7 import javax.persistence.Embedded;
 8 import javax.persistence.Entity;
 9 import javax.persistence.FetchType;
10 import javax.persistence.MapKey;
11 import javax.persistence.OneToMany;
12 import javax.persistence.Version;
13 import model.BaseEntity;
14 import org.hibernate.annotations.DynamicInsert;
15 import org.hibernate.annotations.DynamicUpdate;
16
17 @Entity
18 @DynamicInsert
19 @DynamicUpdate
20 public class Cat extends BaseEntity{
21     /**
22      * 实体类
23      */
24     private static final long serialVersionUID = -2776330321385582872L;
25
26     private Map<String,Hobby> hobbies;
27
28     private String cat_name;
29     private Name name;
30     private int version;
31
32     @Version
33     public int getVersion() {
34         return version;
35     }
36
37     public void setVersion(int version) {
38         this.version = version;
39     }
40
41     public String getCat_name() {
42         return cat_name;
43     }
44
45     public void setCat_name(String cat_name) {
46         this.cat_name = cat_name;
47     }
48
49     @Embedded
50     @AttributeOverrides({
51             @AttributeOverride(name = "first_name", column = @Column(name = "first_name")),
52             @AttributeOverride(name = "last_name", column = @Column(name = "last_name")) })
53     public Name getName() {
54         return name;
55     }
56
57     public void setName(Name name) {
58         this.name = name;
59     }
60     /*
61      * mappedBy属性:
62      * 如果关系是单向的,则该关联提供程序确定拥有该关系的字段。
63      * 如果关系是双向的,则将关联相反(非拥有)方上的 mappedBy 元素设置为拥
64      * 有此关系的字段或属性的名称
65      */
66     @OneToMany(mappedBy = "cat", cascade = { CascadeType.ALL }, fetch = FetchType.EAGER)
67     @MapKey(name="id")
68     public Map<String, Hobby> getHobbies() {
69         return hobbies;
70     }
71
72     public void setHobbies(Map<String, Hobby> hobbies) {
73         this.hobbies = hobbies;
74     }
75 }

Hobby.java

 1 package b10_OneToMany_Map;
 2 import javax.persistence.Entity;
 3 import javax.persistence.JoinColumn;
 4 import javax.persistence.ManyToOne;
 5 import model.BaseEntity;
 6
 7 @Entity
 8 public class Hobby extends BaseEntity {
 9     /**
10      * 实体类
11      */
12     private static final long serialVersionUID = 4921844599282935594L;
13
14     private String name;
15     private Cat cat;
16
17     public String getName() {
18         return name;
19     }
20     public void setName(String name) {
21         this.name = name;
22     }
23     @ManyToOne
24     @JoinColumn(name = "CAT_ID")
25     public Cat getCat() {
26         return cat;
27     }
28     public void setCat(Cat cat) {
29         this.cat = cat;
30     }
31 }

组件类

 1 package b10_OneToMany_Map;
 2 import java.io.Serializable;
 3 import javax.persistence.Embeddable;
 4
 5 @Embeddable
 6 public class Name implements Serializable {
 7     /**
 8      * 嵌入式组建
 9      */
10     private static final long serialVersionUID = -2776330321385582872L;
11
12     private String first_name;
13     private String last_name;
14     public String getFirst_name() {
15         return first_name;
16     }
17     public void setFirst_name(String first_name) {
18         this.first_name = first_name;
19     }
20     public String getLast_name() {
21         return last_name;
22     }
23     public void setLast_name(String last_name) {
24         this.last_name = last_name;
25     }
26 }

Dao

 1 package daoUtil;
 2 import org.hibernate.HibernateException;
 3 import org.hibernate.Session;
 4 import org.hibernate.SessionFactory;
 5 import org.hibernate.Transaction;
 6 import org.hibernate.cfg.Configuration;
 7 import org.hibernate.service.ServiceRegistry;
 8 import org.hibernate.service.ServiceRegistryBuilder;
 9
10 public class HibernateUtil {
11
12     private static final SessionFactory sessionFactory;
13
14     static {
15         try {
16             Configuration cfg = new Configuration().configure();
17             ServiceRegistry serviceRegistry = new ServiceRegistryBuilder()
18                     .applySettings(cfg.getProperties()).buildServiceRegistry();
19             sessionFactory = cfg.buildSessionFactory(serviceRegistry);
20         } catch (Throwable ex) {
21             throw new ExceptionInInitializerError(ex);
22         }
23     }
24
25     public static Session getSession() throws HibernateException {
26         return sessionFactory.openSession();
27     }
28
29     public static Object save(Object obj){
30         Session session = HibernateUtil.getSession();
31         Transaction tx = null;
32         try {
33             tx = session.beginTransaction();
34             session.save(obj);
35             tx.commit();
36         } catch (RuntimeException e) {
37             if (tx != null) {
38                 tx.rollback();
39             }
40             throw e;
41         } finally {
42             session.close();
43         }
44         return obj;
45     }
46
47     public static void delete(Class<?> clazz,String id){
48         Session session = HibernateUtil.getSession();
49         Transaction tx = null;
50         try {
51             tx = session.beginTransaction();
52             Object obj = session.get(clazz,id);
53             session.delete(obj);
54             tx.commit();
55         } catch (RuntimeException e) {
56             if (tx != null) {
57                 tx.rollback();
58             }
59             throw e;
60         } finally {
61             session.close();
62         }
63     }
64 }

main

 1 package b10_OneToMany_Map;
 2 import java.util.HashMap;
 3 import java.util.Map;
 4 import daoUtil.HibernateUtil;
 5
 6 public class Test_OneToMany_Map {
 7
 8     private Cat save(){
 9
10         Cat cat = new Cat();
11         cat.setCat_name("b10_OneToMany_Map");
12         cat.setName(new Name());
13
14         Map<String, Hobby> hobbies = new HashMap<String,Hobby>();
15         Hobby hobby1 = new Hobby();
16         hobby1.setName("足球");
17         hobbies.put("1",hobby1);
18
19         Hobby hobby2 = new Hobby();
20         hobby2.setName("篮球");
21         hobbies.put("2",hobby2);
22
23         cat.setHobbies(hobbies);
24         hobby1.setCat(cat);
25         hobby2.setCat(cat);
26
27         HibernateUtil.save(cat);
28         return cat;
29     }
30
31     public static void main(String[] args) {
32
33         Cat cat = new Test_OneToMany_Map().save();
34
35         Cat cat1 = (Cat)HibernateUtil.getSession().get(Cat.class, cat.getId());
36         System.out.println(cat1.getId());
37
38         Map<String, Hobby> map = cat1.getHobbies();
39         for (Map.Entry<String, Hobby> entry : map.entrySet()) {
40             System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue().getName());
41         }
42         // delete
43 //        HibernateUtil.delete(Cat.class,cat1.getId());
44     }
45 }

环境:JDK1.6,MAVEN,tomcat,eclipse

源码地址:http://files.cnblogs.com/files/xiluhua/hibernate%40OneToMany_Map.rar

时间: 2024-12-31 10:44:40

Hibernate,JPA注解@OneToMany_Map的相关文章

Java、Hibernate(JPA)注解大全

1.@Entity(name=”EntityName”) 必须,name为可选,对应数据库中一的个表 2.@Table(name=””,catalog=””,schema=””) 可选,通常和@Entity配合使用,只能标注在实体的class定义处,表示实体对应的数据库表的信息 name:可选,表示表的名称.默认地,表名和实体名称一致,只有在不一致的情况下才需要指定表名 catalog:可选,表示Catalog名称,默认为Catalog(“”). schema:可选,表示Schema名称,默认为

hibernate自带的注解和jpa注解的冠希

hibernate是实现了JPA规范,在我们使用hibernate框架的时候,我们引入了hibernate3或者4这个核心包.hibernate-jpa-2.0-api-1.0.0.Final.jar这个包的作用是hibernate jpa实现. 注解的选择,建议采用hibernate jpa,为什么呢,如果你要把你的代码移植到其他框架,比如EJB中,那么你可以不修改任何一句代码,就能实现很好的移植.至于hibernate 的table可能会出现莫名其妙的错误,所以基本上都采用hibernate

Hibernate+JPA(转)

近年来ORM(Object-Relational Mapping)对象关系映射,即实体对象和数据库表的映射)技术市场人声音鼎沸,异常热闹, Sun在充分吸收现有的优秀ORM框架设计思想的基础上,制定了新的JPA(Java Persistence API)规范.JPA Java Persistence API,是Java EE 5的标准ORM接口,也是ejb3规范的一部分. 那么什么是JPA呢?JPA是通过JDK5.0注解或XML描述对象-关系表的映射关系,并将运行期实体对象持久化到数据库中去.

Hibernate+JPA (EntityMange讲解)

近年来ORM(Object-Relational Mapping)对象关系映射,即实体对象和数据库表的映射)技术市场人声音鼎沸,异常热闹, Sun在充分吸收现有的优秀ORM框架设计思想的基础上,制定了新的JPA(Java Persistence API)规范.JPA Java Persistence API,是Java EE 5的标准ORM接口,也是ejb3规范的一部分. 那么什么是JPA呢?JPA是通过JDK5.0注解或XML描述对象-关系表的映射关系,并将运行期实体对象持久化到数据库中去.

Hibernate Annotations 注解

Hibernate Annotations 注解 对于org.hibernate.annotations与org.hibernate.persistence,它的注释比如Columns,可是不知道怎么使用,但是hibernate中也封装了javax.persistence,而且数据库映射注释主要还是使用javax.persistence,即如下注释元素Column,使用规则如下.  分类: Java(66)  [java] view plain copy @Entity 声明当前是一个持久化类

JPA注解实现联合主键

当表中一个主键不能唯一标识一条记录的时候,就需要使用联合主键了,下面是使用JPA注解实现联合主键的代码 1 首先需要建立一个复合主键类,用来存放需要生产联合主键的属性,该类需要实现序列化. package com.ericsson.adp.entity.cons; import java.io.Serializable; public class ConsumerGroupMapPK implements Serializable{ private String msisdn;//电话号码 pr

Hibernate+JPA

参考链接:http://blog.163.com/hero_213/blog/static/398912142010312024809 近年来ORM(Object-Relational Mapping)对象关系映射,即实体对象和数据库表的映射)技术市场人声音鼎沸,异常热闹, Sun在充分吸收现有的优秀ORM框架设计思想的基础上,制定了新的JPA(Java Persistence API)规范.JPA Java Persistence API,是Java EE 5的标准ORM接口,也是ejb3规范

JPA注解catalog

Table Table用来定义entity主表的name,catalog,schema等属性. 元数据属性说明: name: 表名catalog: 对应关系数据库中的catalog,如果在entitybean中设置此属性,将在表名前面加上catalog指定的值,注意catalog的值一定是数据库的名称,不然会生成的sql语句回报找不到表的错误.schema:对应关系数据库中的schemaUniqueConstraints:定义一个UniqueConstraint数组,指定需要建唯一约束的列   

Spring Hibernate JPA 联表查询 复杂查询

(转自:http://www.cnblogs.com/jiangxiaoyaoblog/p/5635152.html) 今天刷网,才发现: 1)如果想用hibernate注解,是不是一定会用到jpa的? 是.如果hibernate认为jpa的注解够用,就直接用.否则会弄一个自己的出来作为补充. 2)jpa和hibernate都提供了Entity,我们应该用哪个,还是说可以两个一起用? Hibernate的Entity是继承了jpa的,所以如果觉得jpa的不够用,直接使用hibernate的即可