日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

dynamic-insert=true dynamic-update=true,插入默认值的情况

發布時間:2024/9/27 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dynamic-insert=true dynamic-update=true,插入默认值的情况 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今天在做一個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語句的執行時間,提高程序的運行效率。
本篇文章來源于 Linux公社網站(www.linuxidc.com)? 原文鏈接:http://www.linuxidc.com/Linux/2012-11/74542.htm

總結

以上是生活随笔為你收集整理的dynamic-insert=true dynamic-update=true,插入默认值的情况的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。