Hibernate中dynamic-insert相關設置

 

 

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語句的執行時間,提升程序的運行效率.spa

相關文章
相關標籤/搜索