配置文件模板

 

 

Hibernate配置文件中映射元素詳解

 

  對象關係的映射是用一個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配置文件的相同的屬性。

 

 

 

<?xml version='1.0' encoding='gb2312'?>
<!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/zfvims</property>
     

 <!--連接數據庫的用戶名-->
     

 <property name="connection.username">zfvims</property>
     

 <!--數據庫用戶密碼-->
  

    <property name="connection.password">leizhimin</property>

       <!--數據庫驅動-->
     

 <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
     

 <!--JDBC連接池(使用內置的連接池)-->
  

     <property name="connection.pool_size">1</property>
     

 <!--設置Hibernate自動管理上下文的策略-->
    

  <property name="current_session_context_class">thread</property>
    

  <!--選擇使用的方言-->
    

  <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
     

 <!--在啓動時刪除並重新創建數據庫-->
    

  <property name="hbm2ddl.auto">create</property>
     

 <mapping resource="events/Event.hbm.xml"/>
    

  <mapping resource="events/Person.hbm.xml"/>
 

  </session-factory>
</hibernate-configuration>

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