我是hibernate的新手。我写了一个包含四个文件的简单程序。 Employee.java 它是一个包含getter n setter的bean类。
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="hbm2ddl.auto">update</property-->
<property name="dialect">org.hibernate.dialect.Oracle9Dialect</property>
<property name="connection.url">dbUrl</property>
<property name="connection.username">uname</property>
<property name="connection.password">pass</property >
<property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<mapping resource="Employee.hbm.xml"/>
</session-factory>
</hibernate-configuration>
Employee.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="hibernate_prj.Employee" table="EMPLOYEE">
<meta attribute="class-description">
This class contains the employee detail.
</meta>
<id name="id" type="int" column="empid">
<generator class="native"/>
</id>
<property name="firstName" column="empname" type="string"/>
<property name="dept" column="empdept" type="string"/>
<property name="salary" column="empsal" type="int"/>
</class>
</hibernate-mapping>
StoreData.java
package hibernate_prj;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
public class StoreData {
public static void main(String[] args) {
Configuration cfg=new Configuration();
cfg.configure("hibernate.cfg.xml");
//creating seession factory object
@SuppressWarnings("deprecation")
SessionFactory factory=cfg.buildSessionFactory();
//creating session object
Session session=factory.openSession();
//creating transaction object
Transaction t=session.beginTransaction();
try{
Employee e1=new Employee();
e1.setId(115);
e1.setFirstName("sonoo");
e1.setDept("jaiswal");
e1.setSalary(100);
session.persist(e1);//persisting the object
t.commit();//transaction is commited
session.close();
}catch(Exception e)
{
System.out.println("E "+e.toString());
}
System.out.println("successfully saved");
}
}
我使用以下sql语句创建了表
create table employee (empid number(2,2),empname VARCHAR2(30), empdept varchar2(10), empsal number(5,2));
但是当我运行这个程序时,我收到以下错误:
org.hibernate.PersistentObjectException:传递给的分离实体 persist:hibernate_prj.Employee
请帮我解决此问题
答案 0 :(得分:1)
您已设置员工的ID(至115),但也将其配置为生成。现在Hibernat认为该实体已经被持久化,因为它有一个id!= null,但它不在会话中......不喜欢它。
删除此行
e1.setId(115);
应该解决问题。
答案 1 :(得分:0)
在这种情况下,persist函数用于更新,这里您的实体不存在于您的数据库中,因此异常告诉您正在尝试更新没有对数据库进行引用的对象(不是链接到数据库中的现有行)。尝试删除id assignement,如果工作使用session.save(e1);
,则会分配ID。