4

プロジェクトを実行すると、以下のような例外が発生します。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>
4

3 に答える 3

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"

于 2013-04-20T09:09:02.840 に答える
0

Pojo で equals/tostring および hash メソッドをオーバーライドしていることを確認してください。

于 2015-02-08T19:26:27.997 に答える
-2

session=HibernateSessionFactory.getSession(); の理由を確認してください。nullになっています。それがヌルポインタの理由です

于 2013-04-20T09:04:47.443 に答える