gpt4 book ai didi

hibernate - 实例的标识符从1更改为2

转载 作者:行者123 更新时间:2023-12-03 14:03:23 24 4
gpt4 key购买 nike

我想做的是读取代码中的文本文件,并将其插入到名为employee1的表中。我收到此错误:

Hibernate: insert into EMPLOYEE1 (NAME, SALARY, MANAGER, ID) values (?, ?, ?, ?) identifier of an instance of com.Employee altered from 1 to 2 Exception in thread "main" org.hibernate.HibernateException: identifier of an instance of com.Employee altered from 1 to 2 at org.hibernate.event.def.DefaultFlushEntityEventListener.checkId(DefaultFlushEntityEventListener.java:51) at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:82) at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:190) at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:70) at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:26) at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:669) at roseindia.tutorial.hibernate.FirstExample.main(FirstExample.java:98)



Employee.java的代码
public class Employee 
{

private int id;
private String name;
private double salary;
private String manager;


public int getId()
{
return id;
}

public void setId(int s)
{
id = s;
}
//***************************************************//
public String getName()
{
return name;
}

public void setName(String s)
{
name = s;
}
//***************************************************//
public double getSalary()
{
return salary;
}

public void setSalary(double s)
{
salary = s;
}
//***************************************************//
public String getManager()
{
return manager;
}

public void setManager(String s)
{
manager = s;
}
}

EmployeeEx.java(执行)的代码
import java.io.File;
import java.util.Scanner;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

import com.Employee;

public class EmployeeEx
{

public static void main(String[] args)
{
Session session = null;

try
{
Transaction transaction = null;

SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
session =sessionFactory.openSession();

Employee em = new Employee();

File f=new File("c:/Class/Employee1.txt") ;
Scanner scan=new Scanner(f);
transaction = session.beginTransaction();
while(scan.hasNext())
{

String line=scan.nextLine();
String empArray[]=line.split(" ");


em.setId(Integer.parseInt(empArray[0]));
em.setName(empArray[1]);
em.setSalary(Double.parseDouble(empArray[2]));
em.setManager(empArray[3]);

session.save(em);
transaction.commit();
}


}
catch(Exception e)
{
System.out.println(e.getMessage());
}
finally
{
session.flush();
session.close();

}


}

}

配置文件:
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">oracle.jdbc.OracleDriver</property>
<property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:XE</property>
<property name="hibernate.connection.username">system</property>
<property name="hibernate.connection.password">system</property>
<property name="hibernate.connection.pool_size">10</property>
<property name="show_sql">true</property>
<property name="dialect">org.hibernate.dialect.OracleDialect</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- Mapping files -->
<mapping resource="contact.hbm.xml"/>
<mapping resource="com.hbm.xml"/>
</session-factory>
</hibernate-configuration>

映射文件:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.Employee" table="EMPLOYEE1">
<id name="id" type="int" column="ID" >
<generator class="assigned"/>
</id>

<property name="name">
<column name="NAME" />
</property>
<property name="salary">
<column name="SALARY"/>
</property>
<property name="manager">
<column name="MANAGER"/>
</property>
</class>

</hibernate-mapping>

最佳答案

实际上,您只有一个Employee实例,并且一次又一次地坚持相同的实例...

Employee em = new Employee();    // Not a right place..

while(scan.hasNext())
{
// Employee em = new Employee(); // Should be here...
em.setId(Integer.parseInt(empArray[0]));
em.setName(empArray[1]);
em.setSalary(Double.parseDouble(empArray[2]));
em.setManager(empArray[3]);
....
}

关于hibernate - 实例的标识符从1更改为2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12008571/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com