程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> hibernate連接sqlserver2000問題的解決(父子關系同時保存時發生 one-to-many & many-to-one)_QQG

hibernate連接sqlserver2000問題的解決(父子關系同時保存時發生 one-to-many & many-to-one)_QQG

編輯:關於SqlServer
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 能成功運行。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved