對象關系的映射是用一個XML文檔來說明的。映射文檔可以使用工具來生成,如XDoclet,Middlegen和AndroMDA等。下面從一個映射的例子開始講解映射元素,映射文件的代碼如下:
<?xml version="1.0"?> <!-- 所有的XML映射文件都需要定義如下所示的DOCTYPE。 Hibernate會先在它的類路徑(classptah)中搜索DTD文件。 --> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- hibernate-mapping有幾個可選的屬性: schema屬性指明了這個映射的表所在的schema名稱。 default-cascade屬性指定了默認的級聯風格 可取值有 none、save、update。 auto-import屬性默認讓我們在查詢語言中可以使用非全限定名的類名 可取值有 true、false。 package屬性指定一個包前綴。 --> <hibernate-mapping schema="schemaName" default-cascade="none" auto-import="true" package="test"> <!--用class元素來定義一個持久化類 --> <class name="People" table="person"> <!-- id元素定義了屬性到數據庫表主鍵字段的映射。--> <id name="id"> <!-- 用來為該持久化類的實例生成唯一的標識 --> <generator class="native"/> </id> <!-- discriminator識別器 是一種定義繼承關系的映射方法--> <discriminator column="subclass" type="character"/> <!-- property元素為類聲明了一個持久化的,JavaBean風格的屬性--> <property name="name" type="string"> <column name="name" length="64" not-null="true" /> </property> <property name="sex" not-null="true" update="false"/> <!--多對一映射關系--> <many-to-one name="friend" column="friend_id" update="false"/> <!--設置關聯關系--> <set name="friends" inverse="true" order-by="id"> <key column="friend_id"/> <!—一對多映射--> <one-to-many class="Cat"/> </set> </class> </hibernate-mapping>
組件應用的方法
組件有兩種類型,即組件(component)和動態組件(dynamic-component)。在配置文件中,component元素為子對象的元素與父類對應表的字段建立起映射關系。然后組件可以聲明它們自己的屬性、組件或者集合。component元素的定義如下所示:
<component name="propertyName" class="className" insert="true|false"
upate="true|false" access="field|property|ClassName">
<property ...../>
<many-to-one .... />
........
</component>
在這段代碼中,name是指屬性名,class是類的名字,insert指的是被映射的字段是否出現在SQL的INSERT語句中,upate指出被映射的字段是否出現在SQL的UPDATE語句中,access指出訪問屬性的策略。
Hiebernate的基本配置
Hibernate的數據庫連接信息是從配置文件中加載的。Hibernate的配置文件有兩種形式:一種是XML格式的文件,一種是properties屬性文件。properties形式的配置文件默認文件名是hibernate.properties,一個properties形式的配置文件內容如下所示:
#指定數據庫使用的驅動類
hibernate.connection.driver_class = com.mysql.jdbc.Driver r
#指定數據庫連接串
hibernate.connection.url = jdbc:mysql://localhost:3306/db
#指定數據庫連接的用戶名
hibernate.connection.username = user
#指定數據庫連接的密碼
hibernate.connection.password = password
#指定數據庫使用的方言
hibernate.dialect = net.sf.hibernate.dialect.MySQLDialect
#指定是否打印SQL語句
hibernate.show_sql=true
在配置文件中包含了一系列屬性的配置,Hibernate將根據這些屬性來連接數據庫。
在XML格式的配置文件中,除了基本的Hibernate配置信息,還可以指定具體的持久化類的映射文件,這可以避免將持久化類的配置文件硬編碼在程序中。XML格式的配置文件的默認文件名為hibernate.cfg.xml,一個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>
<!--顯示執行的SQL語句-->
<property name="show_sql">true</property>
<!--連接字符串-->
<property name="connection.url">jdbc:mysql://localhost:3306/STU</property>
<!--連接數據庫的用戶名-->
<property name="connection.username">root</property>
<!--數據庫用戶密碼-->
<property name="connection.password">root</property>
<!--數據庫驅動-->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!--選擇使用的方言-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!--映射文件 -->
<mapping resource="com/stuman/domain/Admin.hbm.xml" />
<!--映射文件-->
<mapping resource="com/stuman/domain/Student.hbm.xml" />
</session-factory>
</hibernate-configuration>
properties形式的配置文件和XML格式的配置文件可以同時使用。當同時使用兩種類型的配置文件時,XML配置文件中的設置會覆蓋properties配置文件的相同的屬性。