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

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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 能成功运行。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航