错误: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加载,如下:
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation"
value="classpath:hibernate.cfg.xml">
</property>
</bean>
怀疑是不是和这个有关系,换回原先的用dataSource依赖注入方式,就不报错误了。
但是后来换回使用classpath:hibernate.cfg.xml,也正常。。。问题无法重现了。。
参考:1、http://penghao122.javaeye.com/blog/59771
2、http://hi.baidu.com/lissnet/blog/item/a0f2df3da66d2dcd9e3d62cc.html