hibernate连接sqlserver2000问题的解决
TransOrder: set name=OrderItems table=orderitem lazy=false inverse=true cascade=allkey column=Order_ID/one-to-many class=com.kaoyanhelper.dao.OrderItem/ /set
OrderItem: class ...
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.current
Session(); 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 能成功运行。
--------------------------------------