Hibernate詳解(四)---->>關聯關係映射(二)

Hibernate詳解(四)---->>關聯關係映射(二)

 

3、單向一對一

     每個中國公民都有一張身份證,這就是典型的一對一關聯關係。首先,討論單向的一對一,即只考慮從公民這一端能找到它的身份證,而身份證這一端不知道公民的存在。
     有兩種常用的方式可以表示這種一對一關係:基於唯一外鍵關聯方式和基於主鍵關聯方式。

方式一:基於外鍵關聯方式

 


Citizen.java

 

package com.zxf.domain;


/** 公民實體類 */
public class Citizen {
	private Long id;                //對象標識符(OID)
	private String name;            //姓名
	private boolean gender;         //性別
	private IDCard idCard;          //身份證
	
	public Citizen(){}              //無參數的構造方法

	//以下省略所有屬性的getters和setters方法...
}

 

IDCard.java

 

package com.zxf.domain;


/** 身份證實體類 */
public class IDCard {
	private Long id;                //對象標識符(OID)
	private String no;              //身份證編寫

	public IDCard(){}             //無參數的構造方法

	//以下爲所有屬性的getters和setters方法...
}

 

Citizen.hbm.xml

 

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.Citizen" table="citizen">
		<!-- 映射對象標識符 -->
		<id name="id" column="id" type="long">
			<generator class="native" />
		</id>
		<!-- 映射普通屬性 -->
		<property name="name"/>
		<property name="gender"/>
		
		<!-- 用many-to-one元素映射基於唯一外鍵的一對一關聯
		     name屬性:指定關聯的屬性名
		     column屬性:指定此關聯屬性在數據庫表中的外鍵字段名
		     unique屬性:指定值爲“true”來限制多端的多重性爲一
		     cascade屬性:用來指定兩個對象之間的操作聯動關係
		 -->
		<many-to-one name="idCard" 
							column="idcard_id" 
							unique="true"
							cascade="all"/>
	</class>
</hibernate-mapping>

 

IDCard.hbm.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.IDCard" 
	       table="idcard">
		<!-- 映射對象標識符 -->
		<id name="id" column="id" type="long">
			<generator class="native" />
		</id>
		<!-- 映射普通屬性 -->
		<property name="no" not-null="true" />
	</class>
</hibernate-mapping>

 

配置文件:hibernate.cfg.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory>
		
		<!-- 數據庫方言設置 -->
		<property name="hibernate.dialect">
			org.hibernate.dialect.MySQLInnoDBDialect
		</property>
		
		<!-- 數據庫連接參數設置 -->
		<property name="hibernate.connection.driver_class">
			com.mysql.jdbc.Driver
		</property>
		<property 

name="hibernate.connection.url">jdbc:mysql:///hibernate</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">123</property>
	
		<!--實際操作數據庫時是否顯示SQL -->
		<!-- 
		<property name="hibernate.show_sql">true</property>
		<property name="hibernate.format_sql">true</property>
		-->
		
		<!--將數據庫schema的DDL導出到數據庫 -->
		<property name="hibernate.hbm2ddl.auto">update</property>

		<!-- 以下定義實體類與數據庫表的映像文件 -->
		<mapping resource="com/zxf/domain/Citizen.hbm.xml" />
		<mapping resource="com/zxf/domain/IDCard.hbm.xml" />
	</session-factory>
</hibernate-configuration>

 

方式二:基於主鍵關聯方式

citizen表和idcard表具有相同的主鍵。這種實現方式的映射文件如下。

 

Citizen.hbm.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.Citizen" table="citizen">
		<!-- 映射對象標識符 -->
		<id name="id" column="id">
			 <!-- foreign表示使用另外一個相關聯的對象(用property屬性指定

的那個屬性)的標識符 -->
			 <generator class="foreign">
         <param name="property">idCard</param>
       </generator>
		</id>
		<!-- 映射普通屬性 -->
		<property name="name"/>
		<property name="gender"/>
		
		<!-- 用one-to-one元素映射基於主鍵的一對一關聯
		     name屬性:指定關聯的屬性名
		     constrained屬性:true表示該類對應的數據庫表和被關聯的對象所對應

的數據庫表之間,通過一個外鍵引用對主鍵進行約束。
		 -->
		<one-to-one name="idCard" constrained="true"/>
	</class>
</hibernate-mapping>
 

  備註:

      在這個映射文件中,通過指定標識符生成器爲foreign來保證與property屬性指定的對象共享同一個OID。使用one-to-one 元素來映射一對一關聯。通過constrained=true ,添加了把citizen表的主鍵鏈接到idcard表主鍵的外鍵約束,即數據庫保證citizen表的主鍵引用有效的idcard表的主鍵。

 

4、雙向一對一

 

     單向的一對一關聯常用的實現方式有兩種:基於唯一外鍵和基於主鍵。同樣,雙向的一對一關聯也有這兩種常用的實現方式。


方式一:基於外鍵一對一關聯方式

 

Citizen.java

 

package com.zxf.domain;


/** 公民實體類 */
public class Citizen {
	private Long id;                //對象標識符(OID)
	private String name;            //姓名
	private boolean gender;         //性別
	private IDCard idCard;          //身份證
	
	public Citizen(){}              //無參數的構造方法

	//以下爲所有屬性的getters和setters方法...
}

 


IDCard.java

 

package com.zxf.domain;


/** 身份證實體類 */
public class IDCard {
	private Long id;                //對象標識符(OID)
	private String no;              //身份證編寫
	private Citizen citizen;        //所屬公民

	public IDCard(){}               //無參數的構造方法

	//以下爲所有屬性的getters和setters方法...
}

 

Citizen.hbm.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.Citizen" table="citizen">
		<!-- 映射對象標識符 -->
		<id name="id" column="id" type="long">
			<generator class="native" />
		</id>
		<!-- 映射普通屬性 -->
		<property name="name"/>
		<property name="gender"/>
		
		<!-- 用many-to-one元素映射基於唯一外鍵的一對一關聯
		     name屬性:指定關聯的屬性名
		     column屬性:指定此關聯屬性在數據庫表中的外鍵字段名
		     unique屬性:指定值爲“true”來限制多端的多重性爲一
		     cascade屬性:用來指定兩個對象之間的操作聯動關係
		 -->
		<many-to-one name="idCard" 
							column="idcard_id" 
							unique="true"
							cascade="all"/>
	</class>
</hibernate-mapping>

 

IDCard.hbm.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.IDCard" 
	       table="idcard">
		<!-- 映射對象標識符 -->
		<id name="id" column="id" type="long">
			<generator class="native" />
		</id>
		<!-- 映射普通屬性 -->
		<property name="no" not-null="true" />
		<!-- one-to-one映射一對一關聯
		     property-ref屬性:指定反向屬性引用 -->
		<one-to-one name="citizen" property-ref="idCard" />
	</class>
</hibernate-mapping>

 

配置文件:hibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory>
		
		<!-- 數據庫方言設置 -->
		<property name="hibernate.dialect">
			org.hibernate.dialect.MySQLInnoDBDialect
		</property>
		
		<!-- 數據庫連接參數設置 -->
		<property name="hibernate.connection.driver_class">
			com.mysql.jdbc.Driver
		</property>
		<property 

name="hibernate.connection.url">jdbc:mysql:///hibernate</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">123</property>
	
		<!--實際操作數據庫時是否顯示SQL -->
		<!-- 
		<property name="hibernate.show_sql">true</property>
		<property name="hibernate.format_sql">true</property>
		-->
		
		<!--將數據庫schema的DDL導出到數據庫 -->
		<property name="hibernate.hbm2ddl.auto">update</property>

		<!-- 以下定義實體類與數據庫表的映像文件 -->
		<mapping resource="com/zxf/domain/Citizen.hbm.xml" />
		<mapping resource="com/zxf/domain/IDCard.hbm.xml" />
	</session-factory>
</hibernate-configuration>

 

方式二:基於主鍵的雙向一對一關聯方式

       基於主鍵的映射方式,指的是一端的主鍵使用foreign策略來參照另一端的主鍵來生成,這樣兩端就具有相同的主鍵值。當然,關聯的任何一端都可以採用foreign策略來生成主鍵,只是在採用foreign策略生成主鍵的一端要使用one-to-one 元素映射關聯的對象,同時還要添加constrainted=true 屬性。而沒有使用foreign策略生成主鍵的那一端就可能直接使用one-to-one 元素來映射關聯的對象。具體的映射文件如下:

 

  Citizen.hbm.xml

 

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.Citizen" table="citizen">
		<!-- 映射對象標識符 -->
		<id name="id" column="id">
			 <!-- foreign表示使用另外一個相關聯的對象(用property屬性指定

的那個屬性)的標識符 -->
			 <generator class="foreign">
         <param name="property">idCard</param>
       </generator>
		</id>
		<!-- 映射普通屬性 -->
		<property name="name"/>
		<property name="gender"/>
		
		<!-- 用one-to-one元素映射基於主鍵的一對一關聯
		     name屬性:指定關聯的屬性名
		     constrained屬性:true表示該類對應的數據庫表和被關聯的對象所對應

的數據庫表之間,通過一個外鍵引用對主鍵進行約束。
		 -->
		<one-to-one name="idCard" constrained="true" cascade="all"/>
	</class>
</hibernate-mapping>

 

IDCard.hbm.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <!-- 映射持久化類 -->
	<class name="com.zxf.domain.IDCard" 
	       table="idcard">
		<!-- 映射對象標識符 -->
		<id name="id" column="id" type="long">
			<generator class="native" />
		</id>
		<!-- 映射普通屬性 -->
		<property name="no" not-null="true" />
		
		<!-- one-to-one映射一對一關聯 -->
		<one-to-one name="citizen"/>
	</class>
</hibernate-mapping>
 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章