2007-09-03

一个怪异的hibernate保存实体失败问题

关键字: hibernate

以前没有遇到过,因为以前没有用spring。

下面service层代码:

java 代码
  1. public boolean updateOrderBill(Long id) {   
  2.         OrderBill ob = this.getOrderBillDao().getOrderBill(id);   
  3.         ob.setName(ob.Name()+"1");   
  4.         getOrderBillDao().saveOrderBill(ob);   
  5.         return true;   
  6.     }  

junit测试代码:

java 代码
  1. @Test  
  2.     public void testReservFailed(){   
  3.         orderBillService.updateOrderBill(Long.valueOf(12530));   
  4.         OrderBill ob = orderBillService.getOrderBill(Long.valueOf(12530));   
  5.         System.out.println(ob.getName());   
  6.     }  

执行时:根本没有保存进行,并且也没有在控制台看到:update语句

service代码改写成:

java 代码
  1. public boolean updateOrderBill(Long id) {   
  2.         OrderBill ob = this.getOrderBillDao().getOrderBill(id);   
  3.         ob.setHotelName(ob.getName()+"1");   
  4.         getOrderBillDao().excuteUpdate("update OrderBill as obj set obj.name='"+ob.getName()+"1"+"' where obj.orderBillId="+id);   
  5.         return false;   
  6.     }  

就更新成功了。

很奇怪,难道不去判断对象被弄脏了吗?

注意用的版本是:hibernate 3.2.5ga ,spring2.0.6

评论
clh8801 2008-01-23   回复
每次更新操作后都执行一下hibernate提供的flush()方法
valibo 2007-10-29   回复
我也觉得是 hbm文件 和POJO类 有问题 你检查一下这里喽。。。
sys53 2007-10-28   回复
其实我上面只是举了一例子,用String可能不存在,主要是因为Character引起的.
在hibernate的CharacterType里执行下面这个函数报空指针异常,而真正报的时oracle驱动内部的异常.
public void set(PreparedStatement st, Object value, int index) throws SQLException {
		st.setString( index, (value).toString() );
	}

这里,value值是'7'时指这个空指针,还是直接new新对象保存时,没有出错,从数据库获取对象后,部份字段弄脏以后save就这个错误,难道真是oracle驱动问题,用了classes12.jar和classes14.jar都是同样的错误.
抛出异常的爱 2007-10-25   回复
用hsqldb作为测试库。一重启所有的重新来过。
打倒小日本 2007-10-25   回复
测试用例继承了Spring提供的AbstractTransactionalDataSourceSpringContextTests基类了吧?
每次更新操作后都执行一下hibernate提供的flush()方法就可以了
否则hibernate会耍滑头不将更新提交到数据库(也许是为了效率)
ddh9504 2007-10-24   回复
Fly_m 写道
hibernate没有被spring进行事务管理吧.导致commit()这个方法没有被执行,不知道是不是这样?小弟只是猜测一下而已.


问题解决了吗?对于这个问题我建议你先去看看配置文件,然后再看看那个DAO的SAVE方法,这样估记能找一解题的思路,谢谢
avaj 2007-10-23   回复
我遇到过,跟你的情况一摸一样,不过原因正像 Fly_m 说的那样,事务没有提交。
sys53 2007-10-23   回复
经过多次测试,这个bug确实存在,如在eclipse调式下,我在Expressions中手增加了ob.getName();注意在保存之前进行这样的操作,然后在查看相就的ob实体变量,估在hibernate代理变量中的target中的相应name变量为更新,如果我有新的成员变量name1,没有像上面的操作,name1仍然是原值,根本没有弄脏.

不知道有没有人遇到过相关问题?
sys53 2007-09-04   回复
事务已经管理起来了,事实上上面的代码是可执行的,但在web应用下同样的代码不能执行,还在找原因
Fly_m 2007-09-03   回复
hibernate没有被spring进行事务管理吧.导致commit()这个方法没有被执行,不知道是不是这样?小弟只是猜测一下而已.
发表评论

该博客是同时发布到论坛的,无法评论在论坛已被锁定的帖子

sys53
搜索本博客
我的相册
6407dc12-e954-3c4c-881c-c75ee797f0cb-thumb
DSC00526
共 40 张
最近加入圈子
存档
最新评论