Hibernate:映射未找到异常

时间:2013-08-12 11:21:17

标签: java hibernate

从其官方文档开始Hibernate。我陷入了配置xml文件的最基本步骤。虽然我已按照示例中的描述完成了所有操作,但未找到The mapping file

这是一个例外:

Exception in thread "main" org.hibernate.MappingNotFoundException: resource: testing/ground/beans/User.hbm.xml not found
    at org.hibernate.cfg.Configuration.addResource(Configuration.java:728)
    at org.hibernate.cfg.Configuration.parseMappingElement(Configuration.java:2115)
    at org.hibernate.cfg.Configuration.parseSessionFactory(Configuration.java:2087)
    at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:2067)
    at org.hibernate.cfg.Configuration.doConfigure(Configuration.java:2020)
    at org.hibernate.cfg.Configuration.configure(Configuration.java:1935)
    at org.hibernate.cfg.Configuration.configure(Configuration.java:1914)
    at testing.ground.test.HibernateTest.main(HibernateTest.java:14)

带main()的代码:

package testing.ground.test;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

    public class HibernateTest {
        private SessionFactory sessionFactory;

        public static void main(String[] args) {
            HibernateTest ht = new HibernateTest();
            ht.sessionFactory = new Configuration().configure().buildSessionFactory();
            ht.getData();
        }

        public void getData(){
            Session session = this.sessionFactory.getCurrentSession();
            session.beginTransaction();
            List list = session.createQuery("from users").list();
            System.out.println(list);
            session.getTransaction().commit();
            session.close();
        }



    }

Hibernate配置文件:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>

        <!-- Database connection settings -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/somedb?characterEncoding=UTF-8</property>
        <property name="connection.username">username</property>
        <property name="connection.password"/>

        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">1</property>

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

        <mapping resource="testing/ground/beans/User.hbm.xml"/>

    </session-factory>

</hibernate-configuration>

我试图保持文件夹结构与Hiberante示例中的相同:

Screen for package structure

请建议。

4 个答案:

答案 0 :(得分:7)

将user.hbm.xml文件放在testing.ground.beans包

下的资源文件夹中

答案 1 :(得分:4)

看起来你正在使用Maven来构建你的项目。 Maven期望资源(即非Java文件)低于src/main/resources。不是src/main/java

也就是说,找到另一个教程如何使用注释来映射实体。 XML映射已过时,并且比注释更难使用。作为额外的奖励,您还将学习如何使用EclipseLink和所有其他JPA引擎,因为注释是标准的,而XML映射则不是。

答案 2 :(得分:3)

User.hbm.xml移至testing.ground.beans中的正确包裹src/main/resources)。我猜您的构建工具不会从src/main/java

中选择资源

答案 3 :(得分:1)

您也可以使用 <mapping file="src/main/java/testing/ground/beans/User.hbm.xml" />