Ich entwickle eine Web App und stelle sie auf Tomcat 7.0 bereit. Meine App verwendet eine MySQL-Datenbank. Ich habe bereits die Verbindung zwischen App und Datenbank konfiguriert und wollte Hibernate 5.2.5-Unterstützung hinzufügen. Ich kann kommunizieren mit der Datenbank über Hibernate-Konsole mit Konfiguration unten, und es funktioniert, wenn ich es in Nicht-Web-App verwenden. Das Problem ist nur, wenn ich es auf dem Server bereitstellen. Ich bekomme eine WarnungTomcat + Hibernate = keine persistenten Klassen für die Abfrageklasse gefunden
no persistent classes found for query class: from entities.UserH
und dann 500 Serverfehler durch sie verursacht.
Meine Entitätsklasse:
@Entity
@Table(name = "users", uniqueConstraints = {@UniqueConstraint(columnNames = {"id"})})
public class UserH {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id", nullable = false, unique = true, length = 11)
private int id;
@Column(name = "login", nullable = false, length = 45)
private String login;
@Column(name = "name", nullable = false, length = 45)
private String name;
@Column(name = "surname", nullable = false, length = 45)
private String surname;
/* getters and setters*/
}
Mein Hibernate-annotation.cfg.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- Database connection properties - Driver, URL, user, password -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/web-database</property>
<property name="hibernate.connection.username">username</property>
<property name="hibernate.connection.password">password</property>
<!-- org.hibernate.HibernateException: No CurrentSessionContext configured! -->
<property name="hibernate.current_session_context_class">thread</property>
<!-- Mapping with model class containing annotations -->
<mapping class="entities.UserH"/>
</session-factory>
</hibernate-configuration>
Methode, die Benutzer erhalten sollten:
public List<UserH> getAllUsers() {
try (Session session = HibernateUtils.getSessionAnnotationFactory().getCurrentSession()) {
session.beginTransaction();
Query<UserH> usersQuery = session.createQuery("from entities.UserH", UserH.class);
List<UserH> usersList = usersQuery.getResultList();
session.getTransaction().commit();
return usersList;
}
}
Wie ich bereits erwähnt - es funktioniert ok mit normaler App, aber nicht mit Tomcat. Ich habe alle verfügbaren Elemente zu Webartefakten hinzugefügt, aber es hat nicht geholfen. Ich habe sogar versucht, JPA-Unterstützung mit persistance.xml
hinzuzufügen, aber immer noch ohne Glück.
Was könnte sonst noch das Problem sein?
edit: Meine HibernateUtils Klasse:
public class HibernateUtils {
private static SessionFactory sessionAnnotationFactory;
private static SessionFactory buildSessionAnnotationFactory() {
try {
// Create the SessionFactory from hibernate.cfg.xml
Configuration configuration = new Configuration();
configuration.configure("hibernate-annotation.cfg.xml");
System.out.println("Hibernate Annotation Configuration loaded");
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build();
System.out.println("Hibernate Annotation serviceRegistry created");
SessionFactory sessionFactory = configuration.buildSessionFactory(serviceRegistry);
return sessionFactory;
} catch (Throwable ex) {
System.err.println("Initial SessionFactory creation failed." + ex);
throw new ExceptionInInitializerError(ex);
}
}
public static SessionFactory getSessionAnnotationFactory() {
if (sessionAnnotationFactory == null)
sessionAnnotationFactory = buildSessionAnnotationFactory();
return sessionAnnotationFactory;
}
}
Bitte geben Sie Ihren 'HibernateUtils' Klassencode an. – Naros
@Naros, ich habe meinen Beitrag bearbeitet. – Mohru