隨筆-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 閱讀(3216) 評論(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
          我是初學者 請高手寫個完整的更新  回復  更多評論
            

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


          網站導航:
           
          主站蜘蛛池模板: 北川| 嵊州市| 建平县| 全州县| 米林县| 铅山县| 清镇市| 交城县| 金门县| 屏东县| 蛟河市| 乐陵市| 阳新县| 电白县| 民县| 绥江县| 定安县| 城市| 松原市| 滦平县| 阿克陶县| 堆龙德庆县| 墨竹工卡县| 仲巴县| 昆明市| 重庆市| 湖口县| 公主岭市| 定结县| 慈利县| 平安县| 龙海市| 株洲市| 邯郸县| 西盟| 资溪县| 皋兰县| 阿瓦提县| 电白县| 阳东县| 垦利县|