1. 程式人生 > >一口一口吃掉Hibernate(四)——多對一單向關聯映射

一口一口吃掉Hibernate(四)——多對一單向關聯映射

mark frame 自動 exce itl format 表之間 cfg.xml pda

hibernate對於數據庫的操作,全部利用面向對象的思維來理解和實現的。一般的單獨表的映射,相信大家都沒有問題,但是對於一些表之間的特殊關系,Hibernate提供了一些獨特的方式去簡化它。

今天就來說說多對一的關聯映射。

數據庫中有多對一的關系,Hibernate自然也有對象的多對一的關聯關系。比如用戶和用戶組,一個用戶只屬於一個組,一個組有多名用戶。我們就可以說用戶和用戶組的關系就是多對一的關系。用對象的uml圖表示一下:

技術分享

在Hibernate中如何來實現呢?首先定義這兩個實體類:

  1. package com.bjpowernode.hibernate;
  2. /**
  3. * 用戶組
  4. * @author Longxuan
  5. *
  6. */
  7. public class Group {
  8. private int id;
  9. private String name;
  10. public int getId() {
  11. return id;
  12. }
  13. public void setId(int id) {
  14. this.id = id;
  15. }
  16. public String getName() {
  17. return name;
  18. }
  19. public void setName(String name) {
  20. this.name = name;
  21. }
  22. }
  23. package com.bjpowernode.hibernate;
  24. /**
  25. * 用戶類
  26. * @author Longxuan
  27. *
  28. */
  29. public class User {
  30. private int id;
  31. private String name;
  32. private Group group;
  33. public Group getGroup() {
  34. return group;
  35. }
  36. public void setGroup(Group group) {
  37. this.group = group;
  38. }
  39. public int getId() {
  40. return id;
  41. }
  42. public void setId(int id) {
  43. this.id = id;
  44. }
  45. public String getName() {
  46. return name;
  47. }
  48. public void setName(String name) {
  49. this.name = name;
  50. }
  51. }

hibernate.cfg.xml配置文件:

  1. <!DOCTYPE hibernate-configuration PUBLIC
  2. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
  4. <hibernate-configuration>
  5. <session-factory name="foo">
  6. <property name="hibernate.dialect" >org.hibernate.dialect.MySQLDialect</property>
  7. <property name="hibernate.show_sql">true</property><!-- 設置是否顯示生成sql語句 -->
  8. <property name="hibernate.format_sql">false</property><!-- 設置是否格式化sql語句-->
  9. <mapping resource="com/bjpowernode/hibernate/Tables.hbm.xml" />
  10. </session-factory>
  11. </hibernate-configuration>

hibernate.properties配置文件:

  1. ## MySQL
  2. hibernate.dialect org.hibernate.dialect.MySQLDialect
  3. #hibernate.dialect org.hibernate.dialect.MySQLInnoDBDialect
  4. #hibernate.dialect org.hibernate.dialect.MySQLMyISAMDialect
  5. hibernate.connection.driver_class com.mysql.jdbc.Driver
  6. hibernate.connection.url jdbc:mysql://localhost:3306/hibernate_many2one
  7. hibernate.connection.username root
  8. hibernate.connection.password root


這是最基礎的準備工作,多對一映射在對數據進行更改時,會有一些限制。當沒有該用戶組時,添加用戶,就會出錯,當該用戶組有用戶時,刪除該用戶組也會報錯。

我們當然可以按一般的方法來做。添加的時候,先手動添加組,再添加用戶。刪除時,先刪除所有的用戶,再刪除用戶組。但是Hibernate為我們提供了一種便捷的方式——many-to-one。在映射文件hbm.xml中配置後,就可以不用再想那些限制了。Hibernate會自動添加上所引用的數據。

給出映射文件:

  1. <?xml version="1.0"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC
  3. "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  4. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
  5. <hibernate-mapping>
  6. <class name="com.bjpowernode.hibernate.User" table="t_user">
  7. <id name="id">
  8. <generator class="native" />
  9. </id>
  10. <property name="name"></property>
  11. <many-to-one name="group" column="groupid" cascade="save-update"></many-to-one>
  12. </class>
  13. <class name="com.bjpowernode.hibernate.Group" table="t_group">
  14. <id name="id">
  15. <generator class="native" />
  16. </id>
  17. <property name="name"></property>
  18. </class>
  19. </hibernate-mapping>

配置了many-to-one會自動在t_user表中創建外鍵groupid,與t_group的id映射。

技術分享

many-to-one標簽用到了cascade,指定兩個對象之間的操作聯動關系,對一個對象執行了操作之後,對其指定的級聯對象也需要執行相同的操作。其屬性值如下:

  • all:在所有的情況下都執行級聯操作;
  • none:在所有情況下都不執行級聯操作;
  • save-update:在保存和更新的時候執行級聯操作;、
  • delete:在刪除的時候執行級聯操作。

測試類Many2OneTest:

  1. package com.bjpowernode.hibernate;
  2. import junit.framework.TestCase;
  3. import org.hibernate.Session;
  4. public class Many2OneTest extends TestCase {
  5. /**
  6. * 測試添加用戶
  7. */
  8. public void testSave3(){
  9. Session session = null;
  10. try{
  11. session = HibernateUtils.getSession();
  12. session.beginTransaction();
  13. Group group = new Group();
  14. group.setName("提高班");
  15. User user1 = new User();
  16. user1.setName("張三");
  17. user1.setGroup(group);
  18. User user2 = new User();
  19. user2.setName("李四");
  20. user2.setGroup(group);
  21. //普通方法 :必須先保存group,再保存user
  22. //配置了many-to-one 則不用再手動save group了。
  23. //session.save(group);
  24. session.save(user1);
  25. session.save(user2);
  26. session.getTransaction().commit();
  27. }catch(Exception e){
  28. e.printStackTrace();
  29. session.getTransaction().rollback();
  30. }finally{
  31. HibernateUtils.closeSession(session);
  32. }
  33. }
  34. }

結果圖:

技術分享

執行測試前:技術分享 , 執行測試後: 技術分享

用many-to-one進行配置後,hibernate會自動去添加外鍵,而我們做的任何操作都不需要去考慮它的結構,也不用手動去維護這個關系,關系由Hibernate自動維護。這就是Hibernate的魅力所在。

一口一口吃掉Hibernate(四)——多對一單向關聯映射