An internal error occurred during "Generating Artifacts"

错误:An internal error occurred during "Generating Artifacts" Invalid thread access
%workspace%/.metadata/.log文件中的错误信息是org.eclipse.swt.SWTException: Invalid thread access

 

描述:使用hiberate reverse engineering生成pojo,hbm.xml,dao时发生此错误。前一天还正常,今天没有改过什么,却发生错误。

 

原因:未知。。。

 

解决过程:

网上都说是Oracle驱动的问题(参考1、2),驱动原先用的是单独下载的ojdbc14.jar,现在换到用oracle安装目录下的官方jar文件(ora92/jdbc/lib),错误依旧,应该不是驱动的问题。

后来发现生成pojo,hbm.xml都没问题,问题出在生成dao过程中。dao是spring dao。升级至MyEclipse7.0后,反向工程生成的sessionFactory使用了configLocation从hibernate.cfg.xml加载,如下:

   class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
     value="classpath:hibernate.cfg.xml">
  

 

怀疑是不是和这个有关系,换回原先的用dataSource依赖注入方式,就不报错误了。

但是后来换回使用classpath:hibernate.cfg.xml,也正常。。。问题无法重现了。。

 

参考:1、http://penghao122.javaeye.com/blog/59771

2、http://hi.baidu.com/lissnet/blog/item/a0f2df3da66d2dcd9e3d62cc.html

你可能感兴趣的:(An internal error occurred during "Generating Artifacts")