昨天用myeclipse6.5反向生成hibernate的POJO+*.hbm.xml出现这个错误:
……
Association references unmapped class:Appraise
……
昨晚在网上查了半天,没找到解决方法,很郁闷于是睡觉去了。今天继续找原因,终于找到这篇文章了,看了下,我问题的原因基本跟真篇文章描述的八九不离十,照他的办法,把这个错误解决掉了,特意转这篇文章过来了。
1 开始生成的POJO+*.hbm.xml在工程的default包下,之后被我移到了,yangting.bookshop.model包下了,但我没有修改映射文件,于是给我报了以上错误.
2 在每个POJO的映射文件中的<hibernate-mapping package="yangting.bookshop.model">
applicationContext.xml中的片段:
<property name="mappingResources">
<list>
<value>yangting/bookshop/model/Bbs.hbm.xml</value>
<value>yangting/bookshop/model/Book.hbm.xml</value>
<value>yangting/bookshop/model/Manager.hbm.xml</value>
<value>yangting/bookshop/model/Order.hbm.xml</value>
<value>yangting/bookshop/model/OrderDetail.hbm.xml</value>
<value>yangting/bookshop/model/Type.hbm.xml</value>
<value>yangting/bookshop/model/User.hbm.xml</value>
<value>yangting/bookshop/model/Appraise.hbm.xml</value>
</list>
</property>
3 改了之后,又有点不幸,控制台又报了个小错误 :
严重: Exception starting filter Struts2
Caught exception while loading file struts-default .xml - [unknown location]
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadConfigurationFiles(XmlConfigurationProvider.java:839)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadDocuments(XmlConfigurationProvider.java:131)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.init(XmlConfigurationProvider.java:100)
.....
Caused by: java.lang.ClassCastException: org.apache.xerces.parsers.XML11Configuration cannot be cast to org.apache.xerces.xni.parser.XMLParserConfiguration
at org.apache.xerces.parsers.DOMParser.<init>(Unknown Source)
at org.apache.xerces.parsers.DOMParser.<init>(Unknown Source)
解决方法:
移除项目目录中的xerces.jar
there was a conflict between tomcat's internal XML parser and the xerces I was using inside my project.
参考链接:http://www.nabble.com/org.apache.xerces.parsers.XML11Configuration- cannot- be- cast- to-org.apache.xerces.xni.parser.XMLParserConfiguration- td14108368.html
现在问题都解决了。
参考文章:
在用myeclipse的Hibernate插件通过数据表自动生成PO的时候遇到了这样的错误:
Exception in thread "main" org.hibernate.MappingException: Association references unmapped class: User
at org.hibernate.cfg.HbmBinder.bindCollectionSecondPass(HbmBinder.java:2380)
at org.hibernate.cfg.HbmBinder$CollectionSecondPass.secondPass(HbmBinder.java:2662)
at org.hibernate.cfg.CollectionSecondPass.doSecondPass(CollectionSecondPass.java:43)
at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1130)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1286)
at free_50.NewsManager.main(NewsManager.java:17)
然后GG和BD了一阵,都没解决。很烦躁。
之后一个一个文件去看,最后结合之前手工写的PO和查看书籍找到了原因:
因为myeclipse自动生成的*.hbm.xml映射文件出来问题,在进行<many-to-one>的映射中的class设置有误,自动生成的映射文件在这地方只是写上类名,而实际上要写上包括包名在内的类名。
ps:后来发现,原来是我移动了生成后的POJO和映射文件,但是映射文件却没随之更改过来,所以要改地址,其实只要改 变<hibernate-mapping package="model.bean">在这里加入package就OK了,不需要一个个的去改。
只要改过来问题就解决了。
顺便把测试代码发一下,做个记录:
- package SessionFactory;
- import org.hibernate.Session;
- import org.hibernate.Transaction;
- import cn.free_50.model.bean.*;
- public class NewsManager {
- public static void main(String[] args) throws Exception {
- //实例化Session
- Session sess = HibernateSessionFactory.getSession();
- //开始事务
- Transaction tc = sess.beginTransaction();
- User u = new User();
- //设置消息标题和消息内容
- u.setUserName("wl" );
- Group group = new Group();
- group.setGroupName("管理员" );
- group.setGroupDesc("管理论坛事物" );
- u.setGroup(group);
- //保存消息
- sess.save(u);
- //提交事务
- tc.commit();
- //关闭Session
- HibernateSessionFactory.closeSession();
- }
- }