Hibernate错误:org.hibernate.InvalidMappingException:无法解析资源中的映射文档

时间:2013-04-20 08:48:26

标签: java hibernate

当我运行项目时,它会发生如下异常。在我在Hibernate中添加一个视图表之前,每个人都很好地包括Blame.hbm.xml和其他。它可以从数据库中读取数据。 ShowOrderDaoImpl.java中的异常发生在这句话:session=HibernateSessionFactory.getSession();

我的例外

    org.hibernate.InvalidMappingException: Could not parse mapping document from resource pojo/Blame.hbm.xml
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processHbmXml(Configuration.java:3415)
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processHbmXmlQueue(Configuration.java:3404)
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processMetadata(Configuration.java:3392)
    at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1341)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1737)
    at session.factory.HibernateSessionFactory.rebuildSessionFactory(HibernateSessionFactory.java:75)
    at session.factory.HibernateSessionFactory.getSession(HibernateSessionFactory.java:57)
    at dao.impl.ShowOrderDaoImpl.queryTradesByBid(ShowOrderDaoImpl.java:24)
    at test.testHibernate.main(testHibernate.java:45)
Caused by: org.hibernate.DuplicateMappingException: Duplicate class/entity mapping pojo.Blame
ok
    at org.hibernate.cfg.Configuration$MappingsImpl.addClass(Configuration.java:2580)
    at org.hibernate.cfg.HbmBinder.bindRoot(HbmBinder.java:174)
    at org.hibernate.cfg.Configuration$MetadataSourceQueue.processHbmXml(Configuration.java:3412)
    ... 8 more
java.lang.NullPointerException
    at dao.impl.ShowOrderDaoImpl.queryTradesByBid(ShowOrderDaoImpl.java:25)
    at test.testHibernate.main(testHibernate.java:45)

我的hibernate.cfg.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
                                         "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
 <session-factory>
  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
  <property name="hibernate.connection.password">root</property>
  <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/disputesystem</property>
  <property name="hibernate.connection.username">root</property>
  <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
  <property name="hibernate.show_sql">true</property>
  <mapping resource="pojo/Blame.hbm.xml"/>
  <mapping resource="pojo/Buyer.hbm.xml"/>
  <mapping resource="pojo/Dispute.hbm.xml"/>
  <mapping resource="pojo/Evidence.hbm.xml"/>
  <mapping resource="pojo/Goods.hbm.xml"/>
  <mapping resource="pojo/Message.hbm.xml"/>
  <mapping resource="pojo/Record.hbm.xml"/>
  <mapping resource="pojo/Seller.hbm.xml"/>
  <mapping resource="pojo/Staff.hbm.xml"/>
  <mapping resource="pojo/Trade.hbm.xml"/>
  <mapping resource="pojo/Fund.hbm.xml"/>
  <mapping resource="pojo/Showorderbybid.hbm.xml"/>
 </session-factory>
</hibernate-configuration>

我的ShowOrderDaoImpl.java文件

package dao.impl;

import java.util.ArrayList;
import java.util.Date;
import java.util.Iterator;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;

import pojo.Showorderbybid;
import session.factory.HibernateSessionFactory;
import dao.intf.ShowOrderDao;

public class ShowOrderDaoImpl implements ShowOrderDao{

    @Override
    public List<Showorderbybid> queryTradesByBid(String bid) throws Exception {
        Session session=null;
        Transaction transaction=null;
        List<Showorderbybid> orders=new ArrayList<Showorderbybid>();
        try {
            session=HibernateSessionFactory.getSession();
            transaction=session.beginTransaction();
            Query query=session.createQuery("from Showorderbybid where bid=?");
            query.setParameter(0, bid);
            orders=(List<Showorderbybid>)query.list();
            List CountView = new ArrayList(); 
            Iterator it = orders.iterator(); 
            while (it.hasNext()) {
                Object[] all = (Object[]) it.next(); 
                Showorderbybid countViewId = new Showorderbybid(); 
                countViewId.setAmount((Integer) all[0]); 
                countViewId.setBid((String) all[1]); 
                countViewId.setDetail((String) all[2]); 
                countViewId.setGid((String)all[3]); 
                countViewId.setGname((String)all[4]);
                countViewId.setLogistics((String)all[5]);
                countViewId.setSid((String)all[6]);
                countViewId.setSname((String)all[7]);
                countViewId.setStatus((String)all[8]);
                countViewId.setTid((String)all[9]);
                countViewId.setTotalmoney((Integer) all[10]);
                countViewId.setTradetime((Date)all[11]);
                orders.add(countViewId);  
            } 

        } catch (Exception e) {
            e.printStackTrace(); 
        }finally{
            HibernateSessionFactory.closeSession();
        }
        return orders;
    }

}

我的Blame.hbm.xml文件

    <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2013-4-19 23:02:05 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
    <class name="pojo.Blame" table="blame" catalog="disputesystem">
        <id name="id" type="java.lang.Integer">
            <column name="id" />
            <generator class="identity" />
        </id>
        <many-to-one name="dispute" class="pojo.Dispute" fetch="select">
            <column name="disputeid" length="20" not-null="true" />
        </many-to-one>
        <property name="blametime" type="timestamp">
            <column name="blametime" length="19" not-null="true" />
        </property>
        <property name="content" type="string">
            <column name="content" length="1000" />
        </property>
    </class>
</hibernate-mapping>

3 个答案:

答案 0 :(得分:3)

看起来pojo.Blame还有另一个映射。您可能遇到copy/paste错误:

<class name="pojo.Blame"

在另一个hbm文件中。

Caused by: org.hibernate.DuplicateMappingException: Duplicate class/entity mapping pojo.Blame

表示当到达hbm文件时,它已经有一个名为pojo.Blame的类的定义。

在某些文件中看起来像这样:

<mapping resource="pojo/Blame.hbm.xml"/>
<mapping resource="pojo/Buyer.hbm.xml"/>
<mapping resource="pojo/Dispute.hbm.xml"/>
<mapping resource="pojo/Evidence.hbm.xml"/>
<mapping resource="pojo/Goods.hbm.xml"/>
<mapping resource="pojo/Message.hbm.xml"/>
<mapping resource="pojo/Record.hbm.xml"/>
<mapping resource="pojo/Seller.hbm.xml"/>
<mapping resource="pojo/Staff.hbm.xml"/>
<mapping resource="pojo/Trade.hbm.xml"/>
<mapping resource="pojo/Fund.hbm.xml"/>
<mapping resource="pojo/Showorderbybid.hbm.xml"/>

错位<class name="pojo.Blame"

答案 1 :(得分:0)

确保你已经覆盖了Pojo中的equals / tostring和hash方法

答案 2 :(得分:-2)

检查session为什么= HibernateSessionFactory.getSession();变得空了。这就是空指针

的原因