hibernate dynamic-update(轉)

今天在update記錄的時候遇到一個問題
我從數據庫裏查詢出一條數據 並在頁面顯示出來 修改之
但是問題就出在表單提交之後了 我數據庫中有很多字段 但是我更新的只有幾個字段
如果用hibernate的update會更新所有的字段 包括沒有發生變化的字段 也就是說會把你不想改變的字段全部清空
這樣的話更新數據可是相當的麻煩 有沒有簡便的方法呢 ? 有 hibernate提供了dynamic-update屬性 你只要設置爲true就可以在更新的時候只更新發生改變的字段 其餘字段保持數據庫中的原有值。
但是這個dynamic-update=‘true’只在如下情況下有效:
1 同一個session中
Session s = openSession();
tx = s.beginTx();
User user = s.load(User.class, id);
user.setName('xuly');
tx.commit();
s.close();
Ok 這樣只會更新name一個字段 其他的字段不會被更新
如果在session1中load一個po 然後在session2中 update 對不起 這樣不管用
那麼我跨session的時候能不能使用dynamic-update呢? 可以
用merge()

 

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

發佈了34 篇原創文章 · 獲贊 0 · 訪問量 1322
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章