Hibernate的getSession.save()方法无法保存对象!急,waitting online!

我使用SSH开发的一项目最近遇到一个非常棘手的问题,有一张订单表SaleOrder,字段稍微有点多,添加数据的时候由于是同时插入多个表的记录所以放在一个Transaction中保持一致性,DEBUG调试数据执行到插入订单对象的语句时就卡住不动了,也不报异常,本人对Hibernate的知识了解甚少,希望各位高人多多指教。

是不是主键策略的问题?起初我以为是连接池的问题,但是其他的插入查询语句都正常,唯独对订单的插入和修改不行。

创建订单的Dao函数:
[code="java"]
public boolean createSaleOrder(SaleOrder so, Orderappend oa,
List spList) {
Session ses = getSessionFactory().openSession();
Transaction tran = ses.beginTransaction();
try {
tran.begin();
Serializable serialOa = ses.save(oa);
Orderappend orderappend = (Orderappend) ses.get(Orderappend.class,
serialOa);
so.setOrderappend(orderappend);// 设置订单附加信息
Serializable serialSo = ses.save(so); // DEBUG调试时执行到这里就卡住不动了,show_sql语句也打印出来了
SaleOrder tempSo = (SaleOrder) ses.get(SaleOrder.class, serialSo);
for (SaleProduct sp : spList) {
sp.setSaleOrder(tempSo);
ses.save(sp);
}
tran.commit();
} catch (Exception ex) {
tran.rollback();
} finally {
ses.close();
}
return tran.wasCommitted();
}

[/code]

SaleOrder表是使用MyEclipse自动生成的映射文件:
[code="xml"]
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">





















































































































[/code]
[b]问题补充:[/b]

还有修改订单的函数也有这种现象,所以我感觉是订单对象的问题,跟连接池和其他应该没关系,我用的是C3p0和jtds。

3个回答

我还是怀疑有人锁表,实在不行彻底重新启动下数据库。我以前碰到过这样的问题,也让我找了好久。

被人锁表了吧? 查下数据库 看是不是有人锁表。

你整理一下,把要级联的对象家caseade="save-update"

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问