gpt4 book ai didi

java - 无法添加或更新子行: a foreign key constraint fails using Hibernate Framework

转载 作者:行者123 更新时间:2023-11-29 18:15:52 25 4
gpt4 key购买 nike

有人可以帮我解决这个问题吗?

我试图在系统中一次保存一个学生的记录,并将其保存到数据库中的不同表中,但在保存时出现错误。

涉及4个类,即Personalinfo.java(父类), Student.java(子类扩展 Personalinfo.java)、Students_Credentials.java(链接到 Student.java)和 ManageStudent.class(包含保存学生记录的方法)

Error

Database Design

代码如下:

PersonalInfo.java

//PersonalInfo.java

@Entity
@Table(name="personal_info")
@Inheritance(strategy=InheritanceType.JOINED)
public class Personalinfo {
@Id
@GeneratedValue
@Column(name="personalid")
private long personalUID;
@Column(name="lastname")
private String lastname;
@Column(name="firstname")
private String firstname;
@Column(name="middlename")
private String middlename;
@Column(name="Suffix")
private String suffix;
@Column(name="gender")
private String gender;
@Column(name="homeaddress")
private String homeaddress;
@Column(name="birthdate")
private String birthdate;
@Column(name="bloodtype")
private String bloodtype;
@Column(name="contactno")
private String contactno;
@Column(name="email")
private String email;
@Column(name="cplastname")
private String cplastname;
@Column(name="cpfirstname")
private String cpfirstname;
@Column(name="cpmiddlename")
private String cpmiddlename;
@Column(name="cphomeaddress")
private String cphomeaddress;
@Column(name="cpcontactno")
private String cpcontactno;
@Column(name="photo")
private Blob photo;
@Column(name="note")
private String note;

//(Netbeans)Automated Get & Set Method..

}

Student.java

//Student.java

@Entity
@Table(name="student")
@PrimaryKeyJoinColumn(name="personalid")

public class Student extends Personalinfo {

@Column(name="studentidno",unique=true,nullable=false)
private String stud_id;

@Column(name="gradeschool")
private String grade_school;

@Column(name="gs_aygraduated")
private String gs_ay_graduated;

@Column(name="highschool")
private String high_school;

@Column(name="hs_aygraduated")
private String hs_ay_graduated;

@Column(name="college")
private String College;

@Column(name="c_aygraduated")
private String c_ay_graduated;

//(Netbeans)Automated Get & Set Method..

}

Students_Credentials.java

@Entity
@Table(name="students_credentials")

public class Students_Credentials {

@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="studentscredentialsid",unique=true,nullable=false)
private long stud_credentials_id;

@Column(name="credentialsnamesubmitted")
private String credentials_name_submitted;


@ManyToOne(optional = false)
@JoinColumn(name="studentidno")
private Student Student;

//(Netbeans)Automated Get & Set Method..

}

ManageStudent.java

public static void addStudent(String Lastname,String Firstname,String Middlename,String Suffix,String ContactNo.......)
{
Session session = NewHibernateUtil.getSessionFactory().openSession();
Transaction tx = null;
try
{
//***personal_info table(Parent Class) and student table(Student Class extends Personal_info Class) ***

tx = session.beginTransaction();
Student stud=new Student();
stud.setLastname(Lastname);
stud.setFirstname(Firstname);
stud.setMiddlename(Middlename);
stud.setSuffix(Suffix);
stud.setGender(Gender);
stud.setGender(Gender);
stud.setHomeaddress(HomeAddress);
stud.setBirthdate(Birthdate);
stud.setContactno(ContactNo);
stud.setEmail(Email);
stud.setCplastname(CPLastname);
stud.setCpfirstname(CPFirstname);
stud.setCpmiddlename(CPMiddlename);
stud.setCphomeaddress(CPHomeAddress);
stud.setCpcontactno(CPContactNo);
stud.setPhoto(Photo);
stud.setNote(Note);
stud.setStud_id(IDno);
stud.setGrade_school(GradeSchool);
stud.setGs_ay_graduated(GSAYGraduated);
stud.setHigh_school(HighSchool);
stud.setHs_ay_graduated(HSAYGraduated);
stud.setCollege(College);
stud.setC_ay_graduated(CollAYGraduated);


//***students_credentials table(Students_Credentials class)***

Students_Credentials Stud_Cred0=new Students_Credentials("Form 138");
Students_Credentials Stud_Cred1=new Students_Credentials("NSO");
Students_Credentials Stud_Cred2=new Students_Credentials("HD");

Stud_Cred0.setStudent(stud);
Stud_Cred1.setStudent(stud);
Stud_Cred2.setStudent(stud);

session.persist(stud);

session.persist(Stud_Cred0);
session.persist(Stud_Cred1);
session.persist(Stud_Cred2);


tx.commit();
}
catch (HibernateException e)
{
if (tx != null) {
tx.rollback();
}
e.printStackTrace();
}
finally
{
session.close();
}
}

最佳答案

这对于评论来说太长了,我想格式化一些代码。这不是完整的答案,这是我对如何解决这个问题的猜测。

导致您的错误的原因是 Hibernate 正在尝试保存 StudentCredentials 对象,而它所附加的 Student 对象上也没有 id。该 ID 不存在,或者由于某种原因与学生对象上的 ID 不匹配。

我自己从未管理过 Hibernate 事务和 session 。我一直在 Spring 中使用 Hibernate,它为我管理事务。

如果我必须猜测(我强调,这是一个完整的猜测),我会说你必须执行以下操作。

create Student
save student
commit **this should put a generated id on the student record**
set Student on Student_Credentials objects
save Student Credentials objects

请注意,如果您单独使用 Hibernate,那么这就是您的决定,但是如果您可以选择将 Hibernate 与 Spring 之类的集成,以便为您管理所有细节和样板文件,那么您通常会这样做你的生活更轻松。

关于java - 无法添加或更新子行: a foreign key constraint fails using Hibernate Framework,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47026913/

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