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