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