Hibernate插入和修改資料到資料庫中時不修改存在預設值欄位

來源:互聯網
上載者:User

說明:

今天在做一個OA的簡單增刪除該查的時候,有一個時間類型的欄位(資料插入時間),本身想著,這個欄位直接中Oracle資料庫設定一個Default Value ,就不用再前台install這個欄位的值了,但是後時間操作中發現插入的時候如果不通過hql去寫代碼的話,而是通過hibernate的介面getHibernateTemplate().saveOrUpdate(entity);的話,就出現問題,插入的時間類型欄位的值是null,tmd有點鬱悶,不好意思又說髒話了,也是當時頭有點昏,呵呵。後來,一想如果通過getHibernateTemplate().saveOrUpdate(entity);這個借口,如果沒有設定值,那麼就會設定null,所有出現了這個問題。查看了下hibernate的介面文檔,一看,原來是這樣的。

需要添加下面的參數在*.hbm.xml中class節點設定,如下

一是將dynamic-insert設定為true

二是將對應欄位的屬性設定not-null為false

<hibernate-mapping>
<class name="com.tom.hibernate.xxxx" table="xxx schema="xxx" dynamic-insert="true" dynamic-update="true">

<property name="entryDate" type="java.util.Date">
<column name="ENTRY_DATE" length="7" not-null="false"/>
</property>

用拿來主義)貼過來一個這個介面說明:

下面是有關其它配置的說明

Hibernate允許我們在對應檔裡控制insert和update語句的內容.比如在對應檔中<property 元素中的update屬性設定成為false,那麼這個欄位,將不被包括在基本的update語句中,修改的時候,將不包括這個欄位了.insert同理.dynamic動態SQL語句的配置也是很常用的.下面介紹配置SQL語句的具體屬性:
1)<property>元素 insert屬性:設定為false,在insert語句中不包含這個欄位,表示永遠不會被插入,預設true
2)<property>元素 update屬性:設定為false,在update語句中不包含這個欄位,表示永遠不會被修改,預設true
3)<class>元素 mutable屬性:設定為false就是把所有的<property>元素的update屬性設定為了false,說明這個對象不會被更新,預設true
4)<property>元素 dynamic-insert屬性:設定為true,表示insert對象的時候,產生動態insert語句,如果這個欄位的值是null就不會加入到insert語句當中.預設false
5)<property>元素 dynamic-update屬性,設定為true,表示update對象的時候,產生動態update語句,如果這個欄位的值是null就不會被加入到update語句中,預設false
6)<class>元素 dynamic-insert屬性:設定為true,表示把所有的<property>元素的dynamic-insert屬性設定為true,預設false
7)<class>元素 dynamic-update屬性:設定為true,表示把所有的<property>元素的dynamic-update屬性設定為true,預設false

Hibernate產生動態SQL語句的消耗的系統資源(比如CPU,記憶體等)是很小的,所以不會影響到系統的效能,如果表中包含N多欄位,建議把dynamic-update屬性和insert屬性設定為true,這樣在插入和修改資料的時候,語句中只包括要插入或者修改的欄位.可以節省SQL語句的執行時間,提高程式的運行效率.

另外一種做法請看如下配置:

Hibernate <property>配置<property name="name" unique="true" not-null="true" update="false" length="25"/>

<property>元素 insert屬性:設定為false,在insert語句中不包含這個欄位,表示永遠不會被插入。預設true。

<property>元素 update屬性:設定為false,在update語句中不包含這個欄位,表示永遠不會被修改。預設true。

<class>元素 mutable屬性:設定為false,就是把所有的<property>元素的update屬性設定為了false,說明這個對象不會被更新。預設true。

<property>元素 dynamic-insert屬性:設定為true,表示insert對象的時候,產生動態insert語句,如果這個欄位的值是null就不會加入到insert語句當中。預設false

<property>元素 dynamic-update屬性:設定為true,表示update對象的時候,產生動態update語句,如果這個欄位的值是null就不會被加入到update語句中。預設false

<class>元素 dynamic-insert屬性:設定為true,表示把所有的<property>元素的dynamic-insert屬性設定為true。預設false

<class>元素 dynamic-update屬性:設定為true,表示把所有的<property>元素的dynamic-update屬性設定為true。預設false

dynamic-update,如果一個表欄位比較多,並且經常只是更新一條記錄的一兩個欄位,避免了過多無用的sql語句,動態更新會更有效。應用程式會增加工作量,但是資料庫會減少工作量。在插入和修改資料的時候,語句中只包括要插入或者修改的欄位,可以節省SQL語句的執行時間,提高程式的運行效率。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.