隨筆-10  評論-66  文章-1  trackbacks-0
          我有一張數據表USER,里面已有數據了,現在我只想更新這張數據表里的某個字段,不知有沒有方法在hibernate可以像用SQL語句那樣直接更新只想更改的字段,而不是先load出來再save? 如: 數據表USER create table user( id int primary key ,name varchar(20), age int); 代碼 User user = new User(); user.setId(new Integer(1)); user.setName("name"); user.setAge(new Integer(21)); Session session = HibernateSessionFactory.getCurrentSession(); session.save(user); 當我去更新時, User user = new User(); user.setId(new Integer(1)); user.setName("name2"); Session session = HibernateSessionFactory.getCurrentSession(); session.update(user); 這時Age的值就變成了NULL了,我現在就想當我去更新時(不用先load出來),Age的值不會改變, 希望各位指點下,謝謝
          posted on 2006-09-06 16:50 javadragon 閱讀(3218) 評論(4)  編輯  收藏

          評論:
          # re: 用hibernate更新數據時出現的問題 2006-09-06 20:13 | 布衣郎
          你用的是hibernate 2 還是 hibernate 3
          如果是3的話
          Session s= HibernateSessionFactory.getCurrentSession();

          s.createQuery( "update user u set age= 1" ).executeUpdate();  回復  更多評論
            
          # re: 用hibernate更新數據時出現的問題 2006-09-13 14:46 | javadragon
          我用的是hibernate 3的,現在我每更新一次數據都要load一次,
          如此一來,就會影響更新的效率,不知兄弟(布衣郎)有沒有更好的方法  回復  更多評論
            
          # re: 用hibernate更新數據時出現的問題 2006-09-15 17:11 | 安文豪
          如果是Hibernate3的話,可以直接使用native sql 去實現你的要求。做法和普通的jdbc一樣。如果不習慣。布衣郎 說的方法也是可行的!
            回復  更多評論
            
          # 我是初學者 請高手寫個完整的更新 2008-04-04 13:04 | keling
          我是初學者 請高手寫個完整的更新  回復  更多評論
            

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 桓仁| 江安县| 凤庆县| 武义县| 阜康市| 新源县| 高青县| 崇左市| 前郭尔| 历史| 陵川县| 西峡县| 始兴县| 兴国县| 龙门县| 祁阳县| 深圳市| 固始县| 鄄城县| 乌兰察布市| 黄石市| 长汀县| 舒城县| 高平市| 林芝县| 日照市| 宁河县| 大关县| 崇仁县| 凤翔县| 济阳县| 城步| 新沂市| 上思县| 吉林省| 南陵县| 于都县| 清丰县| 福建省| 莒南县| 吉水县|