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

作者:网络 来源:佚名 更新时间:2008-11-23 17:18:58 点击:

transorder: <set name="orderitems" table="orderitem" lazy="false" inverse="true" cascade="all">  <key column="order_id"/>  <one-to-many class="com.kaoyanhelper.dao.orderitem"/>       </set>

orderitem: <class name="orderitem" table="orderitem"> <id column="orderitem_id" name="id"  type="java.lang.integer"> <generator class="identity" /> </id><many-to-one class="com.xx.dao.transorder" name="transorder" column="order_id"/> </class>

测试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

<property name="hibernate.connection.url">   jdbc:microsoft:sqlserver://localhost:1433;selectmethod=cursor;databasename=yourdb  </property>

selectmethod=cursor; 默认是selectmethod=diret;

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

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


商业源码热门下载www.html.org.cn