數(shù)據(jù)庫中的一個字段默認(rèn)為0,但是在用hibernate的添加之后,默認(rèn)字段竟然不是0,為NULL.
查了一下.發(fā)現(xiàn)想要讓默認(rèn)字段生效.需要在*.hbm.xml添加一些參數(shù),如下.(紅色部分)
<hibernate-mapping>
    <class name="com.scm.domain.SysBumen" table="sys_bumen" catalog="scm" dynamic-insert="true" dynamic-update="true">
..............
    </class>
</hibernate-mapping>


下面是網(wǎng)上搜集的有關(guān)其它配置的說明

Hibernate允許我們在映射文件里控制insert和update語句的內(nèi)容.比如在映射文件中<property 元素中的update屬性設(shè)置成為false,那么這個字段,將不被包括在基本的update語句中,修改的時候,將不包括這個字段了.insert同理.dynamic動態(tài)SQL語句的配置也是很常用的.下面介紹配置SQL語句的具體屬性:
      1)<property>元素 insert屬性:設(shè)置為false,在insert語句中不包含這個字段,表示永遠(yuǎn)不會被插入,默認(rèn)true
      2)<property>元素 update屬性:設(shè)置為false,在update語句中不包含這個字段,表示永遠(yuǎn)不會被修改,默認(rèn)true
      3)<class>元素 mutable屬性:設(shè)置為false就是把所有的<property>元素的update屬性設(shè)置為了false,說明這個對象不會被更新,默認(rèn)true
      4)<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對象的時候,生成動態(tài)的insert語句,如果這個字段的值是null就不會加入到insert語句當(dāng)中.默認(rèn)false
      5)<property>元素 dynamic-update屬性,設(shè)置為true,表示update對象的時候,生成動態(tài)的update語句,如果這個字段的值是null就不會被加入到update語句中,默認(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生成動態(tài)SQL語句的消耗的系統(tǒng)資源(比如CPU,內(nèi)存等)是很小的,所以不會影響到系統(tǒng)的性能,如果表中包含N多字段,建議把dynamic-update屬性和insert屬性設(shè)置為true,這樣在插入和修改數(shù)據(jù)的時候,語句中只包括要插入或者修改的字段.可以節(jié)省SQL語句的執(zhí)行時間,提高程序的運(yùn)行效率.