自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

淺析Hibernate一對多數(shù)據(jù)關(guān)聯(lián)的問題(二)

開發(fā) 后端
這里介紹Hibernate一對多數(shù)據(jù)關(guān)聯(lián)。指的是單向一對多數(shù)據(jù)關(guān)聯(lián)一個用戶有多個地址,在用戶類TUser中包含地址類TAddress集合。

Hibernate一對多數(shù)據(jù)關(guān)聯(lián)。指的是單向一對多數(shù)據(jù)關(guān)聯(lián)一個用戶有多個地址,在用戶類TUser中包含地址類TAddress集合。

Hibernate如果上手了,那么所謂的一對多,多對一,多對多,一對一這些關(guān)系,應(yīng)該很快能理解.下面主要介紹Hibernate一對多的問題。

1.由TUser對象將自身的id賦給addr.user_id,這樣導致addr屬性值變動,在事物提交的時候,會進行update。


1)當save該用戶的時候,

  1. insert into t_address  (user_id, address, zipcode, tel) value (null, "HongKong", "233123", "1123")  

2)當tx.commit()時:

  1. update t_address user_id="1"address="HongKong"zipcode="233123",tel="1123" where id=2

這樣,在save user時,就會出現(xiàn)約束違例。

調(diào)整方法:
可以在定義數(shù)據(jù)表字段時候,不加NOT NULL約束?;蛘咴陂_始為user_id隨意賦一個非空值(因為還要update,不正確也沒關(guān)系),或者將user_id字段從TAddress.hbm.xml中刪除(本例就是這樣實現(xiàn))。但是這些都是權(quán)宜之計,用兩條SQL語句完成一次數(shù)據(jù)庫操作,性能低下。而雙向一對多解決了這個問題。
下面來實現(xiàn)雙向關(guān)聯(lián):修改配置文件 TUser.hbm.xml

  1. xml version="1.0"?> 
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
  3. <hibernate-mapping> 
  4.     <class name="cn.blogjava.start.TUser" table="T_User" catalog="sample" 
  5.      dynamic-update="true" dynamic-insert="true" 
  6.     > 
  7.         <id name="id" type="integer"> 
  8.             <column name="id" /> 
  9.             <generator class="native" /> 
  10.         id> 
  11.         <property name="name" type="string" column="name" /> 
  12.         <property name="age" type="java.lang.Integer" column="age" /> 
  13.  
  14.         <set   
  15.             name="address"   
  16.             table="t_address"   
  17.             inverse="true" 
  18.             cascade="all"   
  19.             order-by="zipcode asc" 
  20.             > 
  21.             <key column="user_id"> 
  22.             key> 
  23.             <one-to-many class="cn.blogjava.start.TAddress" /> 
  24.         set> 
  25.     class> 
  26. hibernate-mapping> 

設(shè)定inverse="true",表明將TUser類作為被動類,將數(shù)據(jù)關(guān)聯(lián)的維護工作交給關(guān)聯(lián)對象TAddress來管理。
在one-to-many模型中,將many一方設(shè)為主控方有助于性能的改善。(讓總理記住每個人困難,但是每個人記住總理方便)

TAddress.hbm.xml

  1. xml version="1.0"?> 
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
  3. <hibernate-mapping> 
  4.     <class name="cn.blogjava.start.TAddress" table="T_Address" catalog="sample"> 
  5.         <id name="id" type="integer"> 
  6.             <column name="id" /> 
  7.             <generator class="native" /> 
  8.         id> 
  9.         <property name="address" type="string" column="address" /> 
  10.         <property name="zipcode" type="string" column="zipcode" /> 
  11.         <property name="tel" type="string" column="tel" /> 
  12.         <property name="type" type="string" column="type" /> 
  13.         <property name="idx" type="java.lang.Integer" column="idx" /> 
  14.         <many-to-one 
  15.                   name="user"   
  16.                   class="cn.blogjava.start.TUser" 
  17.                   cascade="none" 
  18.                   outer-join="auto" 
  19.                   update="true"                    
  20.                   insert="true" 
  21.                   access="property" 
  22.                   column="user_id" 
  23.                   not-null="true" 
  24.         /> 
  25.     class> 
  26. hibernate-mapping> 

2.對TAddress.java做如下改造:去掉user_id字段,增加user字段,和getter,setter方法。

  1. package cn.blogjava.start;  
  2.  
  3. import java.io.Serializable;  
  4.  
  5. public class TAddress implements Serializable {  
  6.       
  7.     private Integer id;  
  8.     private String address;  
  9.     private String zipcode;  
  10.     private String tel;  
  11.     private String type;  
  12.     private Integer idx;  
  13.     private TUser user;  
  14.       
  15.     public TUser getUser() {  
  16.         return user;  
  17.     }  
  18.     public void setUser(TUser user) {  
  19.         this.user = user;  
  20.     }  
  21.     public Integer getId() {  
  22.         return id;  
  23.     }  
  24.     public void setId(Integer id) {  
  25.         this.id = id;  
  26.     }  
  27.     public String getAddress() {  
  28.         return address;  
  29.     }  
  30.     public void setAddress(String address) {  
  31.         this.address = address;  
  32.     }  
  33.     public Integer getIdx() {  
  34.         return idx;  
  35.     }  
  36.     public void setIdx(Integer idx) {  
  37.         this.idx = idx;  
  38.     }  
  39.     public String getTel() {  
  40.         return tel;  
  41.     }  
  42.     public void setTel(String tel) {  
  43.         this.tel = tel;  
  44.     }  
  45.     public String getType() {  
  46.         return type;  
  47.     }  
  48.     public void setType(String type) {  
  49.         this.type = type;  
  50.     }  
  51.     public String getZipcode() {  
  52.         return zipcode;  
  53.     }  
  54.     public void setZipcode(String zipcode) {  
  55.         this.zipcode = zipcode;  
  56.     }  
  57.  
  58. }  

3.測試代碼
既然TUser不維護關(guān)聯(lián)關(guān)系,需要TAddress需要自己來維護TUser,所以需要addr.setUser(user);

  1. package cn.blogjava.start;  
  2.  
  3. import java.util.HashSet;  
  4. import java.util.Iterator;  
  5. import java.util.List;  
  6.  
  7. import junit.framework.Assert;  
  8. import junit.framework.TestCase;  
  9.  
  10. import org.hibernate.HibernateException;  
  11. import org.hibernate.Session;  
  12. import org.hibernate.SessionFactory;  
  13. import org.hibernate.Transaction;  
  14. import org.hibernate.cfg.Configuration;  
  15.  
  16.  
  17. public class HibernateTest extends TestCase {  
  18.       
  19.     Session session = null;  
  20.  
  21.     protected void setUp() {  
  22.         try {  
  23.             Configuration config = new Configuration().configure();  
  24.             SessionFactory sessionFactory = config.buildSessionFactory();  
  25.             session = sessionFactory.openSession();  
  26.               
  27.         } catch (HibernateException e) {  
  28.             e.printStackTrace();  
  29.         }          
  30.     }  
  31.  
  32.     protected void tearDown() {  
  33.         try {  
  34.             session.close();          
  35.         } catch (HibernateException e) {  
  36.             e.printStackTrace();  
  37.         }          
  38.     }      
  39.       
  40.     /** *//**  
  41.      * 對象持久化測試(Insert方法)  
  42.      */          
  43.     public void testInsert() {  
  44.         Transaction tran = null;  
  45.         try {  
  46.           
  47.             TUser user = new TUser();  
  48.             user.setName("byf");  
  49.             user.setAge(new Integer(26));  
  50.               
  51.             TAddress addr = new TAddress();  
  52.             addr.setTel("1123");  
  53.             addr.setZipcode("233123");  
  54.             addr.setAddress("HongKong");  
  55.             addr.setUser(user);  
  56.               
  57.             TAddress addr2 = new TAddress();  
  58.             addr2.setTel("139");  
  59.             addr2.setZipcode("116001");  
  60.             addr2.setAddress("dalian");         
  61.             addr2.setUser(user);  
  62.  
  63.             TAddress addr3 = new TAddress();  
  64.             addr3.setTel("136");  
  65.             addr3.setZipcode("100080");  
  66.             addr3.setAddress("beijing");  
  67.             addr3.setUser(user);  
  68.               
  69.             //設(shè)置關(guān)聯(lián)  
  70.             HashSet set = new HashSet();  
  71.             set.add(addr);  
  72.             set.add(addr2);  
  73.             set.add(addr3);  
  74.             user.setAddress(set);  
  75.                                      
  76.             tran = session.beginTransaction();                                  
  77.             //插入user信息  
  78.             session.save(user);  
  79.             session.flush();  
  80.             tran.commit();  
  81.             Assert.assertEquals(user.getId().intValue()>0 ,true);  
  82.         } catch (HibernateException e) {  
  83.             e.printStackTrace();  
  84.             Assert.fail(e.getMessage());  
  85.             if(tran != null) {  
  86.                 try {  
  87.                     tran.rollback();  
  88.                 } catch (Exception e1) {  
  89.                     e1.printStackTrace();  
  90.                 }  
  91.             }  
  92.         }  
  93.     }  
  94.       
  95.     /** *//**  
  96.      * 對象讀取測試(Select方法)  
  97.      */              
  98.     public void testSelect(){  
  99.         String hql = " from TUser where name='byf'";  
  100.         try {  
  101.             List userList = session.createQuery(hql).list();  
  102.             TUser user = (TUser)userList.get(0);  
  103.             System.out.println("user name is " + user.getName());  
  104.               
  105.             for (Iterator iter = user.getAddress().iterator(); iter.hasNext();) {  
  106.                 TAddress addr = (TAddress) iter.next();  
  107.                 System.out.println("user address is " + addr.getAddress());                  
  108.             }  
  109.             Assert.assertEquals(user.getName(), "byf");  
  110.         } catch (Exception e) {  
  111.             e.printStackTrace();  
  112.             Assert.fail(e.getMessage());  
  113.         }  
  114.     }  

以上介紹Hibernate一對多數(shù)據(jù)關(guān)聯(lián)。

【編輯推薦】

  1. 生成Hibernate Mapping文件的分析
  2. 對Hibernate中g(shù)et()與load()不同點分析
  3. Struts-Spring-Hibernate案例
  4. 簡述Hibernate配置連接池
  5. 淺析Hibernate一對多數(shù)據(jù)關(guān)聯(lián)的問題(一)
責任編輯:仲衡 來源: baidu
相關(guān)推薦

2009-09-23 10:37:50

Hibernate一對

2012-03-21 11:43:41

JavaHibernate

2012-02-08 13:34:08

HibernateJava

2009-09-22 09:55:58

Hibernate實例

2009-06-04 10:34:19

Hibernate一對一對多關(guān)系配置

2009-06-04 16:14:22

Hibernate一對Hibernate一對Hibernate多對

2009-06-03 16:27:27

Hibernate一對一關(guān)系

2010-04-15 09:09:02

Hibernate

2009-06-03 16:18:16

Hibernate關(guān)系代碼實例

2009-08-17 10:34:51

NHibernate一

2009-09-22 17:32:38

Hibernate A

2009-06-24 07:58:52

Hibernate多數(shù)

2009-06-17 14:55:26

Hibernate數(shù)據(jù)

2010-07-07 08:33:09

SQL Server學

2009-09-28 17:23:51

Hibernate E

2009-12-23 09:31:11

寬帶路由上網(wǎng)故障

2009-09-21 13:31:10

Hibernate 3

2012-02-23 09:24:52

大數(shù)據(jù)云計算

2018-04-11 15:33:59

大數(shù)據(jù)塊鏈去中心化

2009-09-21 17:23:49

Hibernate使用
點贊
收藏

51CTO技術(shù)棧公眾號