2013-04-20 67 views
4

當我運行該項目時,它發生如下異常。在Hibernate中添加一個視圖表之前,每一個都包括Blame.hbm.xml等。它可以讀取數據庫中的數據。 session=HibernateSessionFactory.getSession();休眠錯誤:org.hibernate.InvalidMappingException:無法從資源解析映射文檔

我例外

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; 
    } 

} 
:在ShowOrderDaoImpl.java這句話出現異常

我的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> 
+0

異常overrided等號/的toString和哈希methodes ShowOrderDaoImpl.java這句話:session = HibernateSessionFactory.getSession(); – MindHacks 2013-04-20 08:49:58

+0

Showorderbybid是視圖 – MindHacks 2013-04-20 08:51:21

+0

您的原始xml文件在<?xml version =「1.0」?>之前是否包含額外的空格?它不應該在那裏。 – 2013-04-20 08:56:00

回答

-2

檢查session的原因= HibernateSessionFactory.getSession();變得空。這就是空指針的原因

+0

如何檢查? – MindHacks 2013-04-20 09:06:51

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"

+0

你的意思是我應該把class name =「pojo.Blame」粘貼到。或者應該替換哪一句話? – MindHacks 2013-04-20 09:13:23

+1

是的,這個答案似乎是最合乎邏輯的'重複類/實體映射pojo.Blame'。在某個hbm文件中有一個錯字。你有複製粘貼你的HBM文件,並忘記更改映射/表。 – Siddharth 2013-04-20 09:26:36

+0

謝謝,但是我已經檢查了所有的hbm文件,有正確的類名以及表名。因此,我猜這不是複製/粘貼問題。在向Hibernate添加視圖之前,我的項目運行良好。我猜在視圖表「Showorderbybid」中的問題。 – MindHacks 2013-04-20 12:51:33

相關問題