0

I am getting unknown entity exception.I didn't understand why i am getting.

Customer.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


}

Lab.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();
        }


    }

    }

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">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>

Exception in console

org.hibernate.MappingException: Unknown entity: p1.Customer at org.hibernate.metamodel.internal.MetamodelImpl.entityPersister(MetamodelImpl.java:684) at org.hibernate.internal.SessionImpl.getEntityPersister(SessionImpl.java:1692) at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:122) at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:192) at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:38) at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:177) at 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) at org.hibernate.internal.SessionImpl.save(SessionImpl.java:696) at p1.Lab.main(Lab.java:34)

please help thankyou.

nithin
  • 371
  • 9
  • 24
  • 1
    Possible duplicate of [org.hibernate.MappingException: Unknown entity: annotations.Users](https://stackoverflow.com/questions/23214454/org-hibernate-mappingexception-unknown-entity-annotations-users) –  Aug 19 '18 at 19:06
  • that didn't solved my problem – nithin Aug 19 '18 at 19:12
  • 1
    As you are new to Hibernate then you should better used annotations rather than XML. – Jonathan Rosenne Aug 19 '18 at 20:53

2 Answers2

0

It seems there is a typo in your hibernate.cfg.xml

<mapping resource="p1.Customer.hbm.xml"/>

It should be

<mapping resource="Customer.hbm.xml"/>
0

You should change the way you get session in class Lab1. It is something like:

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

}

And this is your file resources/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>

Then put your Customer.hbm.xml in the same folder of Entity Customer.java

I tested and it worked!