隨筆-10  評論-66  文章-1  trackbacks-0
          我有一張數(shù)據(jù)表USER,里面已有數(shù)據(jù)了,現(xiàn)在我只想更新這張數(shù)據(jù)表里的某個字段,不知有沒有方法在hibernate可以像用SQL語句那樣直接更新只想更改的字段,而不是先load出來再save? 如: 數(shù)據(jù)表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); 當(dāng)我去更新時, User user = new User(); user.setId(new Integer(1)); user.setName("name2"); Session session = HibernateSessionFactory.getCurrentSession(); session.update(user); 這時Age的值就變成了NULL了,我現(xiàn)在就想當(dāng)我去更新時(不用先load出來),Age的值不會改變, 希望各位指點下,謝謝
          posted on 2006-09-06 16:50 javadragon 閱讀(3218) 評論(4)  編輯  收藏

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

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

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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 津南区| 绵竹市| 富源县| 双辽市| 博客| 平顶山市| 石嘴山市| 恩施市| 买车| 卢湾区| 巴彦淖尔市| 朝阳市| 石嘴山市| 鄂托克前旗| 都昌县| 安达市| 井陉县| 榆林市| 屏山县| 改则县| 山东省| 清水河县| 汉中市| 名山县| 阿鲁科尔沁旗| 当涂县| 边坝县| 乌兰浩特市| 吐鲁番市| 凤山市| 余江县| 乌兰县| 淮安市| 隆回县| 乌拉特中旗| 桃江县| 达孜县| 玛曲县| 巴楚县| 右玉县| 柏乡县|