Неизвестная сущность: java.lang. Класс с Hibernate 5.3 - PullRequest
0 голосов
/ 22 сентября 2019

Я новичок в hibernate, и я видел много способов создания утилиты для Hibernate.Я думаю, что здесь моя ошибка, но я не уверен.(Использование Oracle 12c и Hibernate 5.3).Моя цель - попытаться проверить способность hibernate хранить таблицу в базе данных (оракул).Что меня беспокоит, так это hibernateUtil, и если это правильно / hibernate.cfg.xml корректен в сопоставлениях / если структура папок верна для сервлета веб-приложения / и если мои аннотации Bean Requirements верны.Я просмотрел другие посты, но все они указывали на проблему импорта сущностей, которую я исправил.Спасибо за помощь.

org.hibernate.MappingException: Unknown entity: java.lang.Class
at org.hibernate.metamodel.internal.MetamodelImpl.entityPersister(MetamodelImpl.java:670)
at org.hibernate.internal.SessionImpl.getEntityPersister(SessionImpl.java:1721)
at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:118)
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:713)
at org.hibernate.internal.SessionImpl.save(SessionImpl.java:705)
at org.hibernate.internal.SessionImpl.save(SessionImpl.java:700)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:567)
at org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:350)
at com.sun.proxy.$Proxy40.save(Unknown Source)
at com.hibernate.DAO.Requirement.addRequirement(Requirement.java:27)
at com.hibernate.DAO.Requirement.main(Requirement.java:40)

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">oracle.jdbc.driver.OracleDriver</property>
    <property name="hibernate.connection.password">*******</property>
    <property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:TCS</property>
    <property name="hibernate.connection.username">TCS</property>
    <property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>
    <property name="hibernate.connection.pool_size">10</property>
    <property name="hibernate.show_sql">true</property>
    <property name="hbm2ddl">create</property>
    <property name="hibernate.current_session_context_class">thread</property>
    <property name="hibernate.jdbc.batch_size">10</property>
    <mapping class="com.hibernate.beans.Requirements"/>
  </session-factory>
</hibernate-configuration>

Requirements.java (я не включал геттеры и сеттеры, так как онине нужны)

package com.hibernate.beans;

import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Embedded;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Requirements {
   @Id
   @GeneratedValue(strategy = GenerationType.SEQUENCE)
   @Column(name="REQ_ID")
   private long REQ_ID;

   @Embedded
   @Basic
   @Column(name="Full_Name", nullable=false)
   private Name name;

   @Basic
   @Column(name= "Account", nullable=false)
   private String account;

   @Basic
   @Column(name= "Skills_Needed", nullable=false)
   private String skillsNeeded;

   @Basic
   @Column(name= "Pending_Requirement", nullable=false)
   private int pendingRequirement;

   @Basic
   @Column(name= "Status", nullable=false)
   private String status;
 }

Requirement.Java

package com.hibernate.DAO;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import com.hibernate.beans.Name;
import com.hibernate.beans.Requirements;
import com.hibernate.util.HibernateUtil;

public class Requirement {

    private static void addRequirement() {
     Session session = HibernateUtil.getSessionFactory().getCurrentSession();
        try {
            session.beginTransaction();
            Requirements re = new Requirements();
            re.setName(new Name("Bob", "Steven"));
            re.setAccount("Verizon");
            re.setPendingRequirement(2);
            re.setStatus("Pending");
            re.setSkillsNeeded("C++");
            session.save(Requirements.class);
            session.getTransaction().commit();
        } catch (Exception e) {
            e.printStackTrace();
            session.getTransaction().rollback();
        } finally {
            session.close();
        }
    }

    public static void main(String[] args) {
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();
        Requirement re = new Requirement(sessionFactory);
        addRequirement();
    }
 }

Структура папок

Folder

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...