首页 > 解决方案 > 通过使用注释在休眠中的未知实体异常

问题描述

我收到未知实体异常。我不明白为什么会收到。

客户.java

package p1;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="customers")
public class Customer {



    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Column(name="cid")
    private int cid;

    @Column(name="cname")
    private String cname;

    @Column(name="email")
    private String email;

    @Column(name="phone")
    private long phone;

    @Column(name="city")
    private String city;

    @Column(name="bal")
    private double bal;

    Customer(){
        System.out.println("default constructor");
    }

    //setters and getters


}

实验室.java

package p1;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;

public class Lab {

    public static void main(String[] args) {

try{


            Configuration cf=new Configuration().configure("p1/hibernate.cfg.xml").addAnnotatedClass(p1.Customer.class);

            StandardServiceRegistryBuilder ssrbuilder=new StandardServiceRegistryBuilder();

            StandardServiceRegistry ssRegistry=ssrbuilder.applySettings(cf.getProperties()).build();

            SessionFactory factory=cf.buildSessionFactory(ssRegistry);

            Session s=factory.openSession();

             org.hibernate.Transaction t=s.beginTransaction();

             p1.Customer c=new Customer();
                c.setCity("Bangalore");
                c.setCname("nithin1");
                c.setEmail("nithin1@gmail.com");
                c.setBal(21);

                 s.save(c);

                 t.commit();
                 s.close();


        }catch (Exception e) {
            e.printStackTrace();
        }


    }

    }

休眠.cfg.xml

  <?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>
        <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:3307/nithin</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
     <property name="hbm2ddl.auto">create</property>
        <property name="show_sql">true</property>

        <mapping class="p1.Customer"/>

    </session-factory>
</hibernate-configuration>

控制台中的异常

org.hibernate.MappingException:未知实体:在 org.hibernate.internal.SessionImpl.getEntityPersister(SessionImpl.java:1692) 在 org.hibernate.metamodel.internal.MetamodelImpl.entityPersister(MetamodelImpl.java:684) 的 p1.Customer .hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:122) 在 org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:192) 在 org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener .java:38) 在 org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:177) 在 org.hibernate.event.internal.DefaultSaveEventListener。performSaveOrUpdate(DefaultSaveEventListener.java:32) at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:73) at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:709) at org.hibernate.internal .SessionImpl.save(SessionImpl.java:701) 在 org.hibernate.internal.SessionImpl.save(SessionImpl.java:696) 在 p1.Lab.main(Lab.java:34)

请帮忙谢谢。

标签: javahibernatehibernate-mapping

解决方案


你应该改变你在 Lab1 中获得会话的方式。它是这样的:

package main;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import p1.Customer;

public class Main {
    private static StandardServiceRegistry registry;
    private static SessionFactory sessionFactory;

    public static void main(String[] args) throws Exception {

    try {

        registry = new StandardServiceRegistryBuilder().configure().build();

        // Create MetadataSources
        MetadataSources sources = new MetadataSources(registry);

        // Create Metadata
        Metadata metadata = sources.getMetadataBuilder().build();

        // Create SessionFactory
        sessionFactory = metadata.getSessionFactoryBuilder().build();

        Session s = sessionFactory.openSession();
        Customer c = new Customer();
        c.setCname("nithin");

        org.hibernate.Transaction t = s.beginTransaction();

        s.save(c);
        t.commit();
        s.close();

    } catch (Exception e) {
        e.printStackTrace();
    }
}

}

这是你的文件资源/hibernate.cfg.xml:

<?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>
    <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="hibernate.connection.password">xxxx</property>
    <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/xxxx</property>
    <property name="hibernate.connection.username">xxxx</property>
    <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

    <property name="show_sql">true</property>
    <mapping resource="p1/Customer.hbm.xml"/>

</session-factory>

然后将您的 Customer.hbm.xml 放在 Entity Customer.java 的同一文件夹中

我测试过,它有效!


推荐阅读