dynamic-insert=true dynamic-update=true,插入默认值的情况
生活随笔
收集整理的這篇文章主要介紹了
dynamic-insert=true dynamic-update=true,插入默认值的情况
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
今天在做一個(gè)OA的簡(jiǎn)單增刪除該查的時(shí)候,有一個(gè)時(shí)間類(lèi)型的字段(數(shù)據(jù)插入時(shí)間),本身想著,這個(gè)字段直接中Oracle數(shù)據(jù)庫(kù)設(shè)置一個(gè)Default Value ,就不用再前臺(tái)install這個(gè)字段的值了,但是后時(shí)間操作中發(fā)現(xiàn)插入的時(shí)候如果不通過(guò)hql去寫(xiě)代碼的話,而是通過(guò)hibernate的接口getHibernateTemplate().saveOrUpdate(entity);的話,就出現(xiàn)問(wèn)題,插入的時(shí)間類(lèi)型字段的值是null,tmd有點(diǎn)郁悶,不好意思又說(shuō)臟話了,也是當(dāng)時(shí)頭有點(diǎn)昏,呵呵。后來(lái),一想如果通過(guò)getHibernateTemplate().saveOrUpdate(entity);這個(gè)借口,如果沒(méi)有設(shè)置值,那么就會(huì)設(shè)置null,所有出現(xiàn)了這個(gè)問(wèn)題。查看了下hibernate的接口文檔,一看,原來(lái)是這樣的。
需要添加下面的參數(shù)在*.hbm.xml中class節(jié)點(diǎn)設(shè)置,如下
一是將dynamic-insert設(shè)置為true
二是將對(duì)應(yīng)字段的屬性設(shè)置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>
用拿來(lái)主義)貼過(guò)來(lái)一個(gè)這個(gè)接口說(shuō)明:
下面是有關(guān)其它配置的說(shuō)明
Hibernate允許我們?cè)谟成湮募锟刂苅nsert和update語(yǔ)句的內(nèi)容.比如在映射文件中<property 元素中的update屬性設(shè)置成為false,那么這個(gè)字段,將不被包括在基本的update語(yǔ)句中,修改的時(shí)候,將不包括這個(gè)字段了.insert同理.dynamic動(dòng)態(tài)SQL語(yǔ)句的配置也是很常用的.下面介紹配置SQL語(yǔ)句的具體屬性:
1)<property>元素 insert屬性:設(shè)置為false,在insert語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被插入,默認(rèn)true
2)<property>元素 update屬性:設(shè)置為false,在update語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被修改,默認(rèn)true
3)<class>元素 mutable屬性:設(shè)置為false就是把所有的<property>元素的update屬性設(shè)置為了false,說(shuō)明這個(gè)對(duì)象不會(huì)被更新,默認(rèn)true
4)<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對(duì)象的時(shí)候,生成動(dòng)態(tài)的insert語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)加入到insert語(yǔ)句當(dāng)中.默認(rèn)false
5)<property>元素 dynamic-update屬性,設(shè)置為true,表示update對(duì)象的時(shí)候,生成動(dòng)態(tài)的update語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)被加入到update語(yǔ)句中,默認(rèn)false
6)<class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true,默認(rèn)false
7)<class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true,默認(rèn)false
Hibernate生成動(dòng)態(tài)SQL語(yǔ)句的消耗的系統(tǒng)資源(比如CPU,內(nèi)存等)是很小的,所以不會(huì)影響到系統(tǒng)的性能,如果表中包含N多字段,建議把dynamic-update屬性和insert屬性設(shè)置為true,這樣在插入和修改數(shù)據(jù)的時(shí)候,語(yǔ)句中只包括要插入或者修改的字段.可以節(jié)省SQL語(yǔ)句的執(zhí)行時(shí)間,提高程序的運(yùn)行效率.
另外一種做法請(qǐng)看如下配置:
Hibernate <property>配置
<property name="name" unique="true" not-null="true" update="false" length="25"/>
<property>元素 insert屬性:設(shè)置為false,在insert語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被插入。默認(rèn)true。
<property>元素 update屬性:設(shè)置為false,在update語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被修改。默認(rèn)true。
<class>元素 mutable屬性:設(shè)置為false,就是把所有的<property>元素的update屬性設(shè)置為了false,說(shuō)明這個(gè)對(duì)象不會(huì)被更新。默認(rèn)true。
<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對(duì)象的時(shí)候,生成動(dòng)態(tài)的insert語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)加入到insert語(yǔ)句當(dāng)中。默認(rèn)false
<property>元素 dynamic-update屬性:設(shè)置為true,表示update對(duì)象的時(shí)候,生成動(dòng)態(tài)的update語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)被加入到update語(yǔ)句中。默認(rèn)false
<class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true。默認(rèn)false
<class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true。默認(rèn)false
dynamic-update,如果一個(gè)表字段比較多,并且經(jīng)常只是更新一條記錄的一兩個(gè)字段,避免了過(guò)多無(wú)用的sql語(yǔ)句,動(dòng)態(tài)更新會(huì)更有效。應(yīng)用程序會(huì)增加工作量,但是數(shù)據(jù)庫(kù)會(huì)減少工作量。在插入和修改數(shù)據(jù)的時(shí)候,語(yǔ)句中只包括要插入或者修改的字段,可以節(jié)省SQL語(yǔ)句的執(zhí)行時(shí)間,提高程序的運(yùn)行效率。
本篇文章來(lái)源于 Linux公社網(wǎng)站(www.linuxidc.com)? 原文鏈接:http://www.linuxidc.com/Linux/2012-11/74542.htm
需要添加下面的參數(shù)在*.hbm.xml中class節(jié)點(diǎn)設(shè)置,如下
一是將dynamic-insert設(shè)置為true
二是將對(duì)應(yīng)字段的屬性設(shè)置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>
用拿來(lái)主義)貼過(guò)來(lái)一個(gè)這個(gè)接口說(shuō)明:
下面是有關(guān)其它配置的說(shuō)明
Hibernate允許我們?cè)谟成湮募锟刂苅nsert和update語(yǔ)句的內(nèi)容.比如在映射文件中<property 元素中的update屬性設(shè)置成為false,那么這個(gè)字段,將不被包括在基本的update語(yǔ)句中,修改的時(shí)候,將不包括這個(gè)字段了.insert同理.dynamic動(dòng)態(tài)SQL語(yǔ)句的配置也是很常用的.下面介紹配置SQL語(yǔ)句的具體屬性:
1)<property>元素 insert屬性:設(shè)置為false,在insert語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被插入,默認(rèn)true
2)<property>元素 update屬性:設(shè)置為false,在update語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被修改,默認(rèn)true
3)<class>元素 mutable屬性:設(shè)置為false就是把所有的<property>元素的update屬性設(shè)置為了false,說(shuō)明這個(gè)對(duì)象不會(huì)被更新,默認(rèn)true
4)<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對(duì)象的時(shí)候,生成動(dòng)態(tài)的insert語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)加入到insert語(yǔ)句當(dāng)中.默認(rèn)false
5)<property>元素 dynamic-update屬性,設(shè)置為true,表示update對(duì)象的時(shí)候,生成動(dòng)態(tài)的update語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)被加入到update語(yǔ)句中,默認(rèn)false
6)<class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true,默認(rèn)false
7)<class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true,默認(rèn)false
Hibernate生成動(dòng)態(tài)SQL語(yǔ)句的消耗的系統(tǒng)資源(比如CPU,內(nèi)存等)是很小的,所以不會(huì)影響到系統(tǒng)的性能,如果表中包含N多字段,建議把dynamic-update屬性和insert屬性設(shè)置為true,這樣在插入和修改數(shù)據(jù)的時(shí)候,語(yǔ)句中只包括要插入或者修改的字段.可以節(jié)省SQL語(yǔ)句的執(zhí)行時(shí)間,提高程序的運(yùn)行效率.
另外一種做法請(qǐng)看如下配置:
Hibernate <property>配置
<property name="name" unique="true" not-null="true" update="false" length="25"/>
<property>元素 insert屬性:設(shè)置為false,在insert語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被插入。默認(rèn)true。
<property>元素 update屬性:設(shè)置為false,在update語(yǔ)句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被修改。默認(rèn)true。
<class>元素 mutable屬性:設(shè)置為false,就是把所有的<property>元素的update屬性設(shè)置為了false,說(shuō)明這個(gè)對(duì)象不會(huì)被更新。默認(rèn)true。
<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對(duì)象的時(shí)候,生成動(dòng)態(tài)的insert語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)加入到insert語(yǔ)句當(dāng)中。默認(rèn)false
<property>元素 dynamic-update屬性:設(shè)置為true,表示update對(duì)象的時(shí)候,生成動(dòng)態(tài)的update語(yǔ)句,如果這個(gè)字段的值是null就不會(huì)被加入到update語(yǔ)句中。默認(rèn)false
<class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true。默認(rèn)false
<class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true。默認(rèn)false
dynamic-update,如果一個(gè)表字段比較多,并且經(jīng)常只是更新一條記錄的一兩個(gè)字段,避免了過(guò)多無(wú)用的sql語(yǔ)句,動(dòng)態(tài)更新會(huì)更有效。應(yīng)用程序會(huì)增加工作量,但是數(shù)據(jù)庫(kù)會(huì)減少工作量。在插入和修改數(shù)據(jù)的時(shí)候,語(yǔ)句中只包括要插入或者修改的字段,可以節(jié)省SQL語(yǔ)句的執(zhí)行時(shí)間,提高程序的運(yùn)行效率。
本篇文章來(lái)源于 Linux公社網(wǎng)站(www.linuxidc.com)? 原文鏈接:http://www.linuxidc.com/Linux/2012-11/74542.htm
總結(jié)
以上是生活随笔為你收集整理的dynamic-insert=true dynamic-update=true,插入默认值的情况的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 全国2020年平均工资 对比一下看
- 下一篇: JavaScript操作select标签