Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·Tomcat5.5.9的安装配置
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·hibernate配置笔记
·构建Linux下IDE环境--Eclipse篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·AOP编程入门--Java篇
·创建文件夹和文件的java代码范例
·Java常见面试题(含答案)
·Java编写的计算器程序及源代码

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
hibernate连接sqlserver2000问题的解决(父子关系同时保存时发生 one-to-many & many-to-one)

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

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




相关文章

相关软件




月光软件程序下载编程文档电脑教程网站设计网址导航网络文学游戏天地幽默笑话生活休闲写作范文安妮宝贝
电脑技术编程开发网络专区谈天说地情感世界游戏元素分类游戏热门游戏体育运动手机专区业余爱好影视沙龙
音乐天地数码广场教育园地科学大观古今纵横谈股论金人文艺术医学保健动漫图酷二手专区地方风情各行各业

月光软件站·版权所有