hibernate 一对多注解开发

hibernate 注解配置一对多关系


     hibernate 2.5开始就可以使用annotation实现实体关系的映射了,减少了配置hbm文件的繁琐,而且annotation也是一种趋势,现在的SSH2的整合都是完全可以用annotation来实现。在以前实现一对多关联的关联式都是使用hbm文件,今天我们来使用annotation试试,同样也能实现其功能。

1.数据库:oracle数据库,有person和address二张表,一对多的关系。

数据库:
[java]  view plain  copy
  1. create table person  
  2.         (  
  3.                 id number(4) not null,  
  4.                 uname varchar (20)  
  5.         );  
  6.         create table address  
  7.                 (  
  8.                         id number(4) not null,  
  9.                 address varchar(20) not null,  
  10.                 personId number(4) not null  
  11.         )  
  12.         alter table person  
  13.         add constraint primary_id parmary key(id)  
  14.         deferrable initially deferred;  


2.Person实体类:

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.zengguo.po;  
  2. import java.io.Serializable;  
  3. import java.util.HashSet;  
  4. import java.util.Set;  
  5. import javax.persistence.CascadeType;  
  6. import javax.persistence.Column;  
  7. import javax.persistence.Entity;  
  8. import javax.persistence.GeneratedValue;  
  9. import javax.persistence.Id;  
  10. import javax.persistence.JoinColumn;  
  11. import javax.persistence.OneToMany;  
  12. import javax.persistence.Table;  
  13. import org.hibernate.annotations.Fetch;  
  14. import org.hibernate.annotations.FetchMode;  
  15. import org.hibernate.annotations.GenericGenerator;  
  16. import org.hibernate.annotations.Parameter;  
  17. @SuppressWarnings(“serial”)  
  18. @Entity  
  19. @Table(name = “person”)  
  20. public class Person implements Serializable {  
  21. //oracle 序列  
  22. @Id  
  23. @GenericGenerator(name = “personGenericGenerator”, strategy = “sequence”,  
  24. parameters = { @Parameter(value = “hibernate_seq”, name = “sequence”) })  
  25. @GeneratedValue(generator=”personGenericGenerator”)  
  26. private long id;  
  27. @Column(name=”uname”)  
  28. private String uname;  
  29. @OneToMany(targetEntity=Address.class,cascade=CascadeType.ALL)  
  30. @Fetch(FetchMode.JOIN)  
  31. //updatable=false很关键,如果没有它,在级联删除的时候就会报错(反转的问题)  
  32. @JoinColumn(name=”personId”,updatable=false)  
  33. private Set<Address> sets = new HashSet<Address>();  
  34. public Set<Address> getSets() {  
  35. return sets;  
  36. }  
  37. public void setSets(Set<Address> sets) {  
  38. this.sets = sets;  
  39. }  
  40. public Person() {  
  41. super();  
  42. }  
  43. public long getId() {  
  44. return id;  
  45. }  
  46. public void setId(long id) {  
  47. this.id = id;  
  48. }  
  49. public String getUname() {  
  50. return uname;  
  51. }  
  52. public void setUname(String uname) {  
  53. this.uname = uname;  
  54. }  
  55. }</span>  


3.Address实体类

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.zengguo.po;  
  2. import javax.persistence.Column;  
  3. import javax.persistence.Entity;  
  4. import javax.persistence.GeneratedValue;  
  5. import javax.persistence.Id;  
  6. import javax.persistence.JoinColumn;  
  7. import javax.persistence.ManyToOne;  
  8. import javax.persistence.Table;  
  9. import org.hibernate.annotations.GenericGenerator;  
  10. import org.hibernate.annotations.Parameter;  
  11. @SuppressWarnings(“serial”)  
  12. @Entity  
  13. @Table(name = “address”)  
  14. public class Address implements java.io.Serializable {  
  15. //使用序列生成主键  
  16. @Id  
  17. @GenericGenerator(name = “addressGenericGenerator”, strategy = “sequence”,  
  18. parameters = { @Parameter(value = “hibernate_seq”, name = “sequence”) })  
  19. @GeneratedValue(generator = “addressGenericGenerator”)  
  20. private long id;  
  21. @Column(name = “address”)  
  22. private String address;  
  23. //多对一,@JoinColumn与@column类似,指定映射的数据库字段  
  24. @ManyToOne(targetEntity = Person.class)  
  25. @JoinColumn(name=”personId”,updatable=false)  
  26. private Person person;  
  27. public Address() {  
  28. super();  
  29. }  
  30. public long getId() {  
  31. return id;  
  32. }  
  33. public void setId(long id) {  
  34. this.id = id;  
  35. }  
  36. public String getAddress() {  
  37. return address;  
  38. }  
  39. public void setAddress(String address) {  
  40. this.address = address;  
  41. }  
  42. public Person getPerson() {  
  43. return person;  
  44. }  
  45. public void setPerson(Person person) {  
  46. this.person = person;  
  47. }  
  48. }</span>  




hibernate一对多mappedBy的用法:(班级classes和学生student,一对多的关系)

[java]  view plain  copy
  1. <span style="font-size:14px;">package oneToMany;   
  2. import java.util.Set;   
  3. import javax.persistence.*;   
  4. /*  
  5. 注意导入时,是导入:import javax.persistence.*;     
  6. 非导入org.hibernate的相关类:import org.hibernate.annotations.Entity;  
  7. */   
  8. @Entity   
  9. @Table(name="classes")   
  10. public class Classes implements Serializable {   
  11.   @Id   
  12.   @GeneratedValue(strategy=GenerationType.AUTO)   
  13.   private int id;   
  14.   private String name;   
  15.       
  16.   @OneToMany(cascade=CascadeType.ALL,mappedBy="classes")      
  17.   private Set<Student> students;   
  18. //getter,setter省略   
  19. }   
  20.   
  21.   
  22. package oneToMany;   
  23. import javax.persistence.*;   
  24. @Entity   
  25. @Table(name="student")   
  26. public class Student implements Serializable  {   
  27.   @Id   
  28.   @GeneratedValue(strategy=GenerationType.AUTO)   
  29.   private int sid;   
  30.       
  31.   private String sname;   
  32.       
  33.   //若有多个cascade,可以是:{CascadeType.PERSIST,CascadeType.MERGE}   
  34.   @ManyToOne(cascade={CascadeType.ALL})           
  35.   @JoinColumn(name="classid")     //student类中对应外键的属性:classid   
  36.   private Classes classes;   
  37. //getter,setter省略   
  38. }   
  39.   
  40.   
  41. public class TestOneToMany {   
  42. /*  
  43. CREATE TABLE    student (    --要定义外键!!!!!!!  
  44.     `sid` double NOT NULL auto_increment,  
  45.     `classid` double NULL,  
  46.     `sname` varchar(255) NOT NULL,  
  47.     PRIMARY KEY    (sid),  
  48.     INDEX par_ind (classid),  
  49.     FOREIGN KEY (classid) REFERENCES classes(id) ON DELETE CASCADE ON UPDATE CASCADE  
  50. ) ENGINE=InnoDB  
  51. */      
  52.   public static void main(String[] args) throws SQLException      
  53.   {   
  54.     try   
  55.     {   
  56.       SessionFactory sf = new AnnotationConfiguration().configure().buildSessionFactory();   
  57.       Session session=sf.openSession();   
  58.       Transaction tx=session.beginTransaction();           
  59. /* 
  60. 因为mappedBy是定义在classes中,即classes类不负责维护级联关系.即维护者是student.所以, 
  61. 1.要将clsses的数据,赋给student,即用student的setClasses()方法去捆定class数据; 
  62. 2.在进行数据插入/更新session.save()/session.update()时,最后操作的是student. 
  63. */  
  64.       Classes classes=new Classes();   
  65.       classes.setName("access");   
  66.           
  67.       Student st1=new Student();   
  68.       st1.setSname("jason");   
  69.       st1.setClasses(classes);   
  70.       session.save(st1);   
  71.           
  72.       Student st2=new Student();   
  73.       st2.setSname("hwj");   
  74.       st2.setClasses(classes);   
  75.       session.save(st2);   
  76.       tx.commit();  
  77. /*  
  78. 输出如下: 
  79. Hibernate: insert into classes (name) values (?) 
  80. Hibernate: insert into student (classid, sname) values (?, ?) 
  81. Hibernate: insert into student (classid, sname) values (?, ?) 
  82. */  
  83. /* 
  84. 因为一端维护关系另一端不维护关系的原因,我们必须注意避免在应用中用不维护关系的类(class)建立关系,因为这样建立的关系是不会在数据库中存储的。 
  85. 如上的代码倒过来,则插入时,student的外键值为空.如下: 
  86. */  
  87. //      Student st1=new Student();   
  88. //      st1.setSname("jason");   
  89. //      session.save(st1);   
  90. //          
  91. //      Student st2=new Student();   
  92. //      st2.setSname("hwj");   
  93. //      session.save(st2);   
  94. //          
  95. //      Set<Student> students=new HashSet<Student>();   
  96. //      students.add(st1);   
  97. //      students.add(st2);   
  98. //          
  99. //      Classes classes=new Classes();   
  100. //      classes.setName("access");   
  101. //      classes.setStudents(students);   
  102. //      session.save(classes);   
  103. /* 
  104. 输出如下: 
  105. Hibernate: insert into student (classid, sname) values (?, ?) 
  106. Hibernate: insert into student (classid, sname) values (?, ?) 
  107. Hibernate: insert into classes (name) values (?) 
  108. */  
  109.     }   
  110.     catch(HibernateException e)   
  111.     {   
  112.       e.printStackTrace();          
  113.     }   
  114.   }   
  115. }  
  116.    
  117. </span>  
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate是一个Java持久化框架,它能够将Java对象映射到数据库中的表格,同时支持各种关系数据库,如MySQL、Oracle等。在Hibernate中,对于一对一、一对多和多对多的关系,我们可以通过以下方式进行映射。 一对一关系:在Hibernate中,可以通过主键关联和外键关联来实现一对一关系的映射。主键关联是指两个实体之间的关联通过主键来进行,可以使用@PrimaryKeyJoinColumn注解将两个实体关联起来。外键关联是指通过一个实体引用另一个实体的主键作为外键,使用@JoinColumn注解来指定外键属性。 一对多关系:在Hibernate中,一对多关系通常通过外键关联来实现。在一的一方,使用@OneToMany注解来定义一对多关系,同时使用@JoinColumn注解指定外键属性。在多的一方,使用@ManyToOne注解来定义多对一关系,并使用@JoinColumn注解指定外键属性。 多对多关系:在Hibernate中,多对多关系通常通过中间表来实现。在多对多的两个实体中,使用@ManyToMany注解来定义多对多关系。同时,需要在中间表中创建两个外键,分别与两个实体的主键关联,并使用@JoinTable注解来指定中间表的表名和两个外键的列名。 总结:通过Hibernate注解方式,可以方便地实现一对一、一对多和多对多关系的映射。通过合理地使用注解,可以减少编写映射文件的工作量,提高开发效率。同时,Hibernate还提供了在运行时自动生成表结构的功能,可以根据Java实体类来动态创建或更新对应的数据库表格,从而提高系统的可维护性和灵活性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值