hibernate连接sqlserver2000问题的解决(父子关系同时保存时发生 one-to-many & many-to-one)

<< 也谈Java并发程序设计的现状和前景 | 教你20法 轻轻松松把 Apache 配置安全 >>
  发布日期:10/01/2008 03:14:41 发布者:[快乐开发网]  来源:[本站]  浏览:[]  评论:[]
字体:    
jdbc:microsoft:sqlserver://Localhost:1433;SelectMethod=cursor;DatabaseName=yourdb

SelectMethod=cursor; 默认是SelectMethod=diret;

我是在hibernate syn中使用的 ,我还改 .hibernateSynchronizer文件 ,没有 改 hibernate.cfg.xml ,呵呵 晕。

最好两个文件都改,改hibernate.cfg.xml 能成功运行。




TransOrder:

OrderItem:

测试main() public static void main(String[] args) throws HibernateException { Session session = HibernateUtil.currentSession(); Transaction tx = session.beginTransaction(); TransOrder order = new TransOrder(); order.setAcceptType("www"); order.setAddress("tom"); order.setCity("changzhou"); OrderItem item = new OrderItem(); item.setItemCount(new Integer(100)); item.setItemMoney("1200.2"); item.setItemType("kysj"); item.setPaperitemId(new Integer(101)); item.setResourceitemId(new Integer(102)); order.getOrderItems().add(item); item.setTransOrder(order);

session.save(order); session.flush(); tx.commit(); HibernateUtil.closeSession(); }

error message:

[Microsoft][SQLServer 2000 Driver for JDBC]Can't start a cloned connection while in manual transaction mode.

解决方法:

居然是ms的问题,搞了几天,浪费了,

一般是当你在一个SQL SERVER的JDBC连接上执行多个STATEMENTS的操作,或者是手动事务状态(AutoCommit=false) 并且使用 direct (SelectMethod=direct) 模式. Direct 模式是默认的模式. 解决办法当你使用手动事务模式时,必须把SelectMethod 属性的值设置为 Cursor, 或者是确保在你的连接上只有一个STATEMENT操作。

设置hibernate.cfg.xml

jdbc:microsoft:sqlserver://Localhost:1433;SelectMethod=cursor;DatabaseName=yourdb

SelectMethod=cursor; 默认是SelectMethod=diret;

我是在hibernate syn中使用的 ,我还改 .hibernateSynchronizer文件 ,没有 改 hibernate.cfg.xml ,呵呵 晕。

最好两个文件都改,改hibernate.cfg.xml 能成功运行。



打印 】【 收藏 】【 推荐 】 
相关文章
·暂无
推荐文章
 ·暂无
热门文章
评一评
正在读取…

  笔名:

  评论:

   

【注】 发表评论必需遵守以下条例: