java - 通过使用注释在休眠中的未知实体异常
问题描述
我收到未知实体异常。我不明白为什么会收到。
客户.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)
请帮忙谢谢。
解决方案
你应该改变你在 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 的同一文件夹中
我测试过,它有效!
推荐阅读
- python - 如何在 FTP 服务器上检查目录中的更改?
- apache - Apache 服务器不允许 HTTP 请求中的授权标头
- excel - 在 OpenOffice Calc 中突出显示列中的重复值
- php - SQLSTATE [22007]:无效的日期时间格式:1366 不正确的整数值:第 1 行的列 'infraction_id' 的整数值:'["1","3","66","68"]'
- forms - 将在此 Flash 应用程序中工作的最大整数(从头开始)
- java - PlayWS - 达到请求超时时如何抛出异常?
- sqlite - 如何在sqlite中选择今天中午12点到第二天早上5点的销售
- c++ - 用 C 向量替换 C++ 向量
- cakephp - 从 cakphp 表单操作中删除 id
- python - 在 Keras 的自定义损失函数中重塑张量