org.hibernate.AnnotationException: No identifier specified for entity: login.Users


Rahul

I got an error requesting the servlet, I tried a lot of workarounds but didn't find a proper solution.

Registration.java (Servlet class file)

package login;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.SessionFactory;

@WebServlet("/Registration")
public class Registration extends HttpServlet {
   private static final long serialVersionUID = 1L;


public Registration() {
    super();
 }


protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

     String username =  request.getParameter("username");
     String password =  request.getParameter("password");
     String name =  request.getParameter("name");

     Users u = new Users();
     u.setUsername(username);
     u.setPassword(password);
     u.setName(name);

     String uname = u.getUsername();
     System.out.println(uname);
     SessionFactory sessionFactory = new                 Configuration().configure().buildSessionFactory();
     Session session = sessionFactory.openSession();
        session.beginTransaction();
        session.save(u);
        session.getTransaction().commit();
        session.close();
        sessionFactory.close();

}

}

Users.java This class is used to store user information in the "Users" table

package login;
import javax.persistence.Entity;
import javax.persistence.Table;
@Entity
@Table(name="Users")
public class Users {
private String username;
private String password;
private String name;
public String getUsername() {
    return username;
}
public void setUsername(String username) {
    this.username = username;
}
public String getPassword() {
    return password;
}
public void setPassword(String password) {
    this.password = password;
}
public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}   
}

hibernate.cfg.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
 <session-factory>
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="connection.url">jdbc:mysql://localhost:3306/login</property>
    <property name="connection.username">root</property>
    <property name="connection.password"></property>

    <property name="connection.pool_size">1</property>
    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

    <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
    <property name="show_sql">true</property>
    <property name="hbm2ddl.auto">create</property>


      <mapping class ="login.Users" /> 

</session-factory>

folder structure

console log

EVERE: Servlet.service() for servlet [Registration] in context with path [/loginapp] threw exception
org.hibernate.AnnotationException: No identifier specified for entity: login.Users
at    org.hibernate.cfg.InheritanceState.determineDefaultAccessType(InheritanceState.java:265)
at org.hibernate.cfg.InheritanceState.getElementsToProcess(InheritanceState.java:211)
at org.hibernate.cfg.AnnotationBinder.bindClass(AnnotationBinder.java:710)
at org.hibernate.boot.model.source.internal.annotations.AnnotationMetadataSourceProcessorImpl.processEntityHierarchies(AnnotationMetadataSourceProcessorImpl.java:245)
at org.hibernate.boot.model.process.spi.MetadataBuildingProcess$1.processEntityHierarchies(MetadataBuildingProcess.java:222)
at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:265)
at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.build(MetadataBuildingProcess.java:83)
at org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:418)
at org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:87)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:692)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:724)
at login.Registration.doPost(Registration.java:47)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:646)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:421)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
Boris

You are missing a field for entity identifier. like this:

    @Id 
    @GeneratedValue
    private long id;

Also don't forget the getter for this field.

Hope this helps.

Related


No identifier specified for entity: XYZ (AnnotationException)

ppst99 entity import javax.persistence.Access; import javax.persistence.AccessType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; @Entit

No identifier specified for entity: XYZ (AnnotationException)

ppst99 entity import javax.persistence.Access; import javax.persistence.AccessType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; @Entit

hibernate: no identifier specified for entity

Patrick H I am trying to build a small project in Hibernate and use mysql docker database for demonstration. Everything worked fine until I added a new class called Flight and a corresponding FlightController. The log says: 2018-12-02 14:42:47,281 DEBUG [main]

Identifier not specified for entity in Java Hibernate

Pratic Josh I am using hibernate and I have tables mapped with beans. If I don't assign any particular column value as @id, it throws a "no identifier specified for entity" error, but it's not a primary key in my datatable. I want to add multiple records with

Identifier not specified for entity in Java Hibernate

Pratik Joshi I am using hibernate and I have the table mapped with beans. If I don't assign any particular column value as @id, it throws a "no identifier specified for entity" error, but it's not a primary key in my datatable. I want to add multiple records w

Identifier not specified for entity in Java Hibernate

Pratic Josh I am using hibernate and I have tables mapped with beans. If I don't assign any particular column value as @id, it throws a "no identifier specified for entity" error, but it's not a primary key in my datatable. I want to add multiple records with