06-hibernate的映射文件詳解

hibernate配置文件與hibernate映射文件之間的關係:

**在這裏插入圖片描述**

hibenrate映射文件的詳解:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">    
<!-- 
    <hibernate-mapping>一般不去配置,採用默認即可。
    schema:指定映射數據庫的schema(模式/數據庫),如果指定該屬性,則表名會自動添加該schema前綴
    package:指定包前綴 指定持久化類所在的包名 這樣之後class子元素中就不必使用全限定性的類名
    default-cascade="none":默認的級聯風格,表與表聯動。
    default-lazy="true":默認延遲加載
 -->
<hibernate-mapping>
    <!-- 
        <class>:使用class元素定義一個持久化類。
        name="cn.javass.user.vo.UserModel":持久化類的java全限定名;
        table="tbl_user":對應數據庫表名,默認持久化類名作爲表名;
        proxy:指定一個接口,在延遲裝載時作爲代理使用,也可在這裏指定該類自己的名字。
        mutable="true":默認爲true,設置爲false時則不可以被應用程序更新或刪除,等價於所有<property>元素的update屬性爲false,表示整個實例不能被更新。
        dynamic-insert="false":默認爲false,動態修改那些有改變過的字段,而不用修改所有字段;
        dynamic-update="false":默認爲false,動態插入非空值字段;
        select-before-update="false":默認爲false,在修改之前先做一次查詢,與用戶的值進行對比,有變化都會真正更新;
        optimistic-lock="version":默認爲version(檢查version/timestamp字段),取值:all(檢查全部字段)、dirty(只檢查修改過的字段);
                                   none(不使用樂觀鎖定),此參數主要用來處理併發,每條值都有固定且唯一的版本,版本爲最新時才能執行操作;
        如果需要採用繼承映射,則class元素下還會增加<subclass.../>元素等用於定義子類。
     -->
    <class name="cn.javass.user.vo.UserModel" table="tbl_user" >
        
        <!-- 
            <id>:定義了該屬性到數據庫表主鍵字段的映射。
            type  指定該標識屬性的數據類型,該類型可以是Hibernate的內建類型,也可以是java類型,如果是java類型則需要使用全限定類名(帶包名)。該屬性可選,如果沒有指定類型, 則hibernate自行判斷該標識屬性數據類型。通常建議設定。
            name="userId":標識屬性的名字;
            column="userId":表主鍵字段的名字,如果不填寫與name一樣;
            
         -->
        <id name="userId">
            <!-- <generator>:指定主鍵由什麼生成,推薦使用uuid,assigned指用戶手工填入。設定標識符生成器
            適應代理主鍵的有:
                increment:有Hibernat自動以遞增的方式生成標識符,每次增量1;
                identity:由底層數據庫生成標識符,前提條件是底層數據庫支持自動增長字段類型。(DB2,MYSQL)
                uuid:用128位的UUID算法生成字符串類型標識符。
            適應自然主鍵:
                assigned:由java程序負責生成標識符,爲了能讓java應用程序設置OID,不能把setId()方法設置成private類型。
                讓應用程序在save()之前爲對象分配一個標識符。相當於不指定<generator.../>元素時所採用的默認策略。
                應當儘量避免自然主鍵
            -->
            <generator class="uuid"/>
        </id>
        
        <!-- 
            <version/>:使用版本控制來處理併發,要開啓optimistic-lock="version"和dynamic-update="true"。
            name="version":持久化類的屬性名,column="version":指定持有版本號的字段名;
         -->
        <version name="version" column="version"/>
        
        <!-- 
            <property>:爲類定義一個持久化的javaBean風格的屬性。
            name="name":標識屬性的名字,以小寫字母開頭;
            column="name":表主鍵字段的名字,如果不填寫與name一樣;
            update="true"/insert="true":默認爲true,表示可以被更新或插入;
            access="property/field":指定Hibernate訪問持久化類屬性的方式。默認property。property表示使用setter/getter方式。field表示運用java反射機制直接訪問類的屬性。
            formula="{select。。。。。}":該屬性指定一個SLQ表達式,指定該屬性的值將根據表達式類計算,計算屬性沒有和它對應的數據列。
            formula屬性允許包含表達式:sum,average,max函數求值的結果。
            例如:formula="(select avg(p.price) from Product P)"
         -->
        <property name="name" column="name" />
        <property name="sex" column="sex"/>
        <property name="age" column="age"/>
        
        <!-- 
            組件映射:把多個屬性打包在一起當一個屬性使用,用來把類的粒度變小。
            <component name="屬性,這裏指對象">
                 <property name="name1"></property>
                 <property name="name2"></property>
             </component>
         -->
         
         <!-- 
             <join>:一個對象映射多個表,該元素必須放在所有<property>之後。
             <join table="tbl_test:子表名">
                 <key column="uuid:子表主鍵"></key>
             <property name="name1:對象屬性" column="name:子表字段"></property>
         </join>
          -->
         
    </class>    
</hibernate-mapping>

引用自:https://www.cnblogs.com/lcycn/p/8126783.html

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