hibernate連線sqlserver2000問題的解決(父子關係同時儲存時發生 one-to-many & many-to-one)
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 能成功執行。