成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺析Hibernate一對多數據關聯的問題(二)

開發 后端
這里介紹Hibernate一對多數據關聯。指的是單向一對多數據關聯一個用戶有多個地址,在用戶類TUser中包含地址類TAddress集合。

Hibernate一對多數據關聯。指的是單向一對多數據關聯一個用戶有多個地址,在用戶類TUser中包含地址類TAddress集合。

Hibernate如果上手了,那么所謂的一對多,多對一,多對多,一對一這些關系,應該很快能理解.下面主要介紹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時,就會出現約束違例。

調整方法:
可以在定義數據表字段時候,不加NOT NULL約束。或者在開始為user_id隨意賦一個非空值(因為還要update,不正確也沒關系),或者將user_id字段從TAddress.hbm.xml中刪除(本例就是這樣實現)。但是這些都是權宜之計,用兩條SQL語句完成一次數據庫操作,性能低下。而雙向一對多解決了這個問題。
下面來實現雙向關聯:修改配置文件 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> 

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

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不維護關聯關系,需要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.             //設置關聯  
  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一對多數據關聯。

【編輯推薦】

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

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一對一對多關系配置

2009-06-04 16:14:22

Hibernate一對Hibernate一對Hibernate多對

2009-06-03 16:27:27

Hibernate一對一關系

2010-04-15 09:09:02

Hibernate

2009-08-17 10:34:51

NHibernate一

2009-06-03 16:18:16

Hibernate關系代碼實例

2009-09-22 17:32:38

Hibernate A

2009-06-17 14:55:26

Hibernate數據

2009-06-24 07:58:52

Hibernate多數

2009-09-28 17:23:51

Hibernate E

2010-07-07 08:33:09

SQL Server學

2009-12-23 09:31:11

寬帶路由上網故障

2009-09-21 13:31:10

Hibernate 3

2009-09-21 17:23:49

Hibernate使用

2009-09-22 13:09:06

Hibernateorm框架

2009-09-24 11:41:46

Hibernate延遲
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品中文字幕 | 婷婷色国产偷v国产偷v小说 | 在线成人免费视频 | 日韩久久中文字幕 | 日韩欧美国产一区二区三区 | 日韩在线看片 | 日中文字幕在线 | 国产精品视频一区二区三区 | 综合第一页 | 精品国产乱码久久久久久蜜臀 | 尤物在线精品视频 | 伊人网综合在线观看 | 午夜激情影院 | 91干b| 国产成人精品综合 | 天天干夜夜操视频 | 亚洲精品一区二区网址 | 成人水多啪啪片 | 成人免费一区二区三区视频网站 | 国产欧美日韩久久久 | 欧美精品一级 | 五月婷婷婷 | av手机免费在线观看 | 免费精品| 国产精品色| 免费观看日韩精品 | 亚洲免费精品 | 亚洲精品视频在线观看免费 | 国产美女视频黄a视频免费 国产精品福利视频 | 国产精品久久久久久 | 欧美综合一区 | av国产精品毛片一区二区小说 | 999精品在线观看 | 天天干天天操天天看 | 国产精品色 | 日本不卡视频 | 国产精品美女久久久久久免费 | 欧美日韩不卡 | 亚洲精品久久久久久久久久久久久 | 中文字幕成人av | av影音资源 |