對象關(guān)系的映射是用一個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屬性指定了默認(rèn)的級聯(lián)風(fēng)格 可取值有 none、save、update。auto-import屬性默認(rèn)讓我們在查詢語言中可以使用非全限定名的類名 可取值有 true、false。package屬性指定一個包前綴。--><hibernate-mapping schema="schemaName" default-cascade="none" auto-import="true" package="test"><!--用class元素來定義一個持久化類 --><class name="People" table="person"><!-- id元素定義了屬性到數(shù)據(jù)庫表主鍵字段的映射。--><id name="id"><!-- 用來為該持久化類的實例生成的標(biāo)識 --><generator/></id><!-- discriminator識別器 是一種定義繼承關(guān)系的映射方法--><discriminator column="subclass" type="character"/><!-- property元素為類聲明了一個持久化的,JavaBean風(fēng)格的屬性--><property name="name" type="string"><column name="name" length="64" not-null="true" /></property><property name="sex"not-null="true" update="false"/><!--多對一映射關(guān)系--><many-to-one name="friend"column="friend_id"update="false"/><!--設(shè)置關(guān)聯(lián)關(guān)系--><set name="friends" inverse="true" order-by="id"><key column="friend_id"/><!—一對多映射--><o(jì)ne-to-many/></set></class></hibernate-mapping>
組件應(yīng)用的方法
組件有兩種類型,即組件(component)和動態(tài)組件(dynamic-component)。在配置文件中,component元素為子對象的元素與父類對應(yīng)表的字段建立起映射關(guān)系。然后組件可以聲明它們自己的屬性、組件或者集合。component元素的定義如下所示:
<component name="propertyName" insert="true|false" upate="true|false" access="field|property|ClassName"> <property ...../><many-to-one .... />........</component>
在這段代碼中,name是指屬性名,class是類的名字,insert指的是被映射的字段是否出現(xiàn)在SQL的INSERT語句中,upate指出被映射的字段是否出現(xiàn)在SQL的UPDATE語句中,access指出訪問屬性的策略。
Hiebernate的基本配置
Hibernate的數(shù)據(jù)庫連接信息是從配置文件中加載的。Hibernate的配置文件有兩種形式:一種是XML格式的文件,一種是properties屬性文件。properties形式的配置文件默認(rèn)文件名是hibernate.properties,一個properties形式的配置文件內(nèi)容如下所示:
#指定數(shù)據(jù)庫使用的驅(qū)動類hibernate.connection.driver_class = com.mysql.jdbc.Driver r#指定數(shù)據(jù)庫連接串hibernate.connection.url = jdbc:mysql://localhost:3306/db#指定數(shù)據(jù)庫連接的用戶名hibernate.connection.username = user#指定數(shù)據(jù)庫連接的密碼hibernate.connection.password = password#指定數(shù)據(jù)庫使用的方言hibernate.dialect = net.sf.hibernate.dialect.MySQLDialect#指定是否打印SQL語句hibernate.show_sql=true
在配置文件中包含了一系列屬性的配置,Hibernate將根據(jù)這些屬性來連接數(shù)據(jù)庫。
在XML格式的配置文件中,除了基本的Hibernate配置信息,還可以指定具體的持久化類的映射文件,這可以避免將持久化類的配置文件硬編碼在程序中。XML格式的配置文件的默認(rèn)文件名為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><!--顯示執(zhí)行的SQL語句--><property name="show_sql">true</property><!--連接字符串--><property name="connection.url">jdbc:mysql://localhost:3306/STU</property><!--連接數(shù)據(jù)庫的用戶名--><property name="connection.username">root</property><!--數(shù)據(jù)庫用戶密碼--><property name="connection.password">root</property><!--數(shù)據(jù)庫驅(qū)動--><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格式的配置文件可以同時使用。當(dāng)同時使用兩種類型的配置文件時,XML配置文件中的設(shè)置會覆蓋properties配置文件的相同的屬性
<?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屬性指定了默認(rèn)的級聯(lián)風(fēng)格 可取值有 none、save、update。auto-import屬性默認(rèn)讓我們在查詢語言中可以使用非全限定名的類名 可取值有 true、false。package屬性指定一個包前綴。--><hibernate-mapping schema="schemaName" default-cascade="none" auto-import="true" package="test"><!--用class元素來定義一個持久化類 --><class name="People" table="person"><!-- id元素定義了屬性到數(shù)據(jù)庫表主鍵字段的映射。--><id name="id"><!-- 用來為該持久化類的實例生成的標(biāo)識 --><generator/></id><!-- discriminator識別器 是一種定義繼承關(guān)系的映射方法--><discriminator column="subclass" type="character"/><!-- property元素為類聲明了一個持久化的,JavaBean風(fēng)格的屬性--><property name="name" type="string"><column name="name" length="64" not-null="true" /></property><property name="sex"not-null="true" update="false"/><!--多對一映射關(guān)系--><many-to-one name="friend"column="friend_id"update="false"/><!--設(shè)置關(guān)聯(lián)關(guān)系--><set name="friends" inverse="true" order-by="id"><key column="friend_id"/><!—一對多映射--><o(jì)ne-to-many/></set></class></hibernate-mapping>
組件應(yīng)用的方法
組件有兩種類型,即組件(component)和動態(tài)組件(dynamic-component)。在配置文件中,component元素為子對象的元素與父類對應(yīng)表的字段建立起映射關(guān)系。然后組件可以聲明它們自己的屬性、組件或者集合。component元素的定義如下所示:
<component name="propertyName" insert="true|false" upate="true|false" access="field|property|ClassName"> <property ...../><many-to-one .... />........</component>
在這段代碼中,name是指屬性名,class是類的名字,insert指的是被映射的字段是否出現(xiàn)在SQL的INSERT語句中,upate指出被映射的字段是否出現(xiàn)在SQL的UPDATE語句中,access指出訪問屬性的策略。
Hiebernate的基本配置
Hibernate的數(shù)據(jù)庫連接信息是從配置文件中加載的。Hibernate的配置文件有兩種形式:一種是XML格式的文件,一種是properties屬性文件。properties形式的配置文件默認(rèn)文件名是hibernate.properties,一個properties形式的配置文件內(nèi)容如下所示:
#指定數(shù)據(jù)庫使用的驅(qū)動類hibernate.connection.driver_class = com.mysql.jdbc.Driver r#指定數(shù)據(jù)庫連接串hibernate.connection.url = jdbc:mysql://localhost:3306/db#指定數(shù)據(jù)庫連接的用戶名hibernate.connection.username = user#指定數(shù)據(jù)庫連接的密碼hibernate.connection.password = password#指定數(shù)據(jù)庫使用的方言hibernate.dialect = net.sf.hibernate.dialect.MySQLDialect#指定是否打印SQL語句hibernate.show_sql=true
在配置文件中包含了一系列屬性的配置,Hibernate將根據(jù)這些屬性來連接數(shù)據(jù)庫。
在XML格式的配置文件中,除了基本的Hibernate配置信息,還可以指定具體的持久化類的映射文件,這可以避免將持久化類的配置文件硬編碼在程序中。XML格式的配置文件的默認(rèn)文件名為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><!--顯示執(zhí)行的SQL語句--><property name="show_sql">true</property><!--連接字符串--><property name="connection.url">jdbc:mysql://localhost:3306/STU</property><!--連接數(shù)據(jù)庫的用戶名--><property name="connection.username">root</property><!--數(shù)據(jù)庫用戶密碼--><property name="connection.password">root</property><!--數(shù)據(jù)庫驅(qū)動--><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格式的配置文件可以同時使用。當(dāng)同時使用兩種類型的配置文件時,XML配置文件中的設(shè)置會覆蓋properties配置文件的相同的屬性

