簡體   English   中英

org.hibernate.PersistentObjectException:傳遞給持久化的分離實體:多對一單向

[英]org.hibernate.PersistentObjectException: detached entity passed to persist: Many to one unidirectional

我正在嘗試在 Spring Boot 中使用 hibernate 進行多對一單向映射。 我有以下學生班 - 許多

package jpa.many.to.one.unidirectional.model;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
 
@Entity
@Table(name = "STUDENT")
public class Student {
 
    @Id
    @GeneratedValue
    @Column(name = "STUDENT_ID")
    private long id;
 
    @Column(name = "FIRST_NAME")
    private String firstName;
 
    @Column(name = "LAST_NAME")
    private String lastName;
 
    @Column(name = "SECTION")
    private String section;
 
    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name="UNIVERSITY_ID")
    private University university;
 
 
    public Student() {
    }
 
    public Student(String firstName, String lastName, String section, University university) {
        this.firstName = firstName;
        this.lastName = lastName;
        this.section = section;
        this.university = university;
    }
 
    public long getId() {
        return id;
    }
 
    public void setId(long id) {
        this.id = id;
    }
 
    public String getFirstName() {
        return firstName;
    }
 
    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }
 
    public String getLastName() {
        return lastName;
    }
 
    public void setLastName(String lastName) {
        this.lastName = lastName;
    }
 
    public String getSection() {
        return section;
    }
 
    public void setSection(String section) {
        this.section = section;
    }
 
    public University getUniversity() {
        return university;
    }
 
    public void setUniversity(University university) {
        this.university = university;
    }
 
    @Override
    public String toString() {
        return "Student [id=" + id + ", firstName=" + firstName + ", lastName="
                + lastName + ", section=" + section + "]";
    }
 
}

大學 - 一個班級

package jpa.many.to.one.unidirectional.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
 
@Entity
@Table(name = "UNIVERSITY")
public class University {
 
    @Id
    @GeneratedValue
    @Column(name = "UNIVERSITY_ID")
    private long id;
 
    @Column(name = "NAME")
    private String name;
 
    @Column(name = "COUNTRY")
    private String country;
 
    public University() {
 
    }
 
    public University(String name, String country) {
        this.name = name;
        this.country = country;
    }
 
    public long getId() {
        return id;
    }
 
    public void setId(long id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getCountry() {
        return country;
    }
 
    public void setCountry(String country) {
        this.country = country;
    }
 
    @Override
    public String toString() {
        return "University [id=" + id + ", name=" + name + ", country=" + country + "]";
    }
 
}

應用程序保存並運行為

package jpa.many.to.one.unidirectional;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;

import jpa.many.to.one.unidirectional.model.Student;
import jpa.many.to.one.unidirectional.model.University;
import jpa.many.to.one.unidirectional.repo.StudentRepo;
import jpa.many.to.one.unidirectional.repo.UniversityRepo;

@SpringBootApplication
public class Application {

    public static void main(String[] args) {
//      SpringApplication.run(Application.class, args);

        ConfigurableApplicationContext configurableApplicationContext = SpringApplication.run(Application.class, args);
        UniversityRepo universityRepo = configurableApplicationContext.getBean(UniversityRepo.class);
        StudentRepo studentRepo = configurableApplicationContext.getBean(StudentRepo.class);

        University university = new University("MG", "India");
        
        Student fstudent = new Student("Deeksha", "Sivakumar", "A", university);
        fstudent.setUniversity(university);
        studentRepo.save(fstudent);
        
        
        Student fstudent1 = new Student("Sivakumar", "Nair", "A", university);
        fstudent1.setUniversity(university);
        studentRepo.save(fstudent1);

    }

}

但我得到了引起:org.hibernate.PersistentObjectException:分離實體傳遞給持久化:jpa.many.to.one.unidirectional.model.University at org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:120)在 org.hibernate.event.service.internal.EventListenerGroupImpl.fireEventOnEachListener(EventListenerGroupImpl.java:113) 在 org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:744) 在 org.hibernate.internal.SessionImpl.persist(SessionImpl) .java:712) 在 org.hibernate.engine.spi.CascadingActions$7.cascade(CascadingActions.java:298) 在 org.hibernate.engine.internal.Cascade.cascadeToOne(Cascade.java:492) 在 org.hibernate.engine .internal.Cascade.cascadeAssociation(Cascade.java:416) at org.hibernate.engine.internal.Cascade.cascadeProperty(Cascade.java:218) at org.hibernate.engine.internal.Cascade.cascade(Cascade.java:151) ) 在 org.hibernate.event.internal.AbstractSaveEventListener.cascadeBeforeSave(AbstractSaveEventListener.java:427) a t org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:264) 位於 org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:193) 位於 org.hibernate.event.inavesaverate. (AbstractSaveEventListener.java:135) at org.hibernate.event.internal.DefaultPersistEventListener.entityIsTransient(DefaultPersistEventListener.java:185) at org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:128) at org.hibernate event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:55) at org.hibernate.event.service.internal.EventListenerGroupImpl.fireEventOnEachListener(EventListenerGroupImpl.java:102) at org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java: 720) 在 org.hibernate.internal.SessionImpl.persist(SessionImpl.java:706) 在 java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native方法)在 java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 在 java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在 java.base/java .lang.reflect.Method.invoke(Method.java:567) at org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:314) at com.sun.proxy.$Proxy55.persist(Unknown Source) ) 在 org.springframework.data.jpa.repository.support.SimpleJpaRepository.save(SimpleJpaRepository.java:554) 在 java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 java.base/jdk.internal .reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 在 java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在 java.base/java.lang.reflect.Method.invoke(Method) .java:567) 在 org.springframework.data.repository.core.support.ImplementationInvocati onMetadata.invoke(ImplementationInvocationMetadata.java:72) 在 org.springframework.data.repository.core.support.RepositoryComposition$RepositoryFragments.invoke(RepositoryComposition.java:382) 在 org.springframework.data.repository.core.support.RepositoryComposition。 invoke(RepositoryComposition.java:205) at org.springframework.data.repository.core.support.RepositoryFactorySupport$ImplementationMethodExecutionInterceptor.invoke(RepositoryFactorySupport.java:550) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java) 186) 在 org.springframework.data.repository.core.support.QueryExecutorMethodInterceptor.doInvoke(QueryExecutorMethodInterceptor.java:155) 在 org.springframework.data.repository.core.support.QueryExecutorMethodInterceptor.invoke(QueryExecutorMethodInterceptor.java:130) .springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) 在 org.springframework.data.projection.DefaultMethod InvokingMethodInterceptor.invoke(DefaultMethodInvokingMethodInterceptor.java:80) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspect7) .springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:118) 在 org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) 在 org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.java:118) .java:139) ...還有 13 個

我在多對一注釋中嘗試了 cascade.merge 和 optional-=false 。 但我得到了上面提到的錯誤,請幫忙

@ManyToOne(cascade = CascadeType.ALL) 在您的情況下似乎是一個壞主意,因為刪除學生會導致刪除相關大學。 由於一所大學可以有多個學生,其他學生將成為孤兒

我認為你應該在 University Entity 中使用這種關系,而不是 Student Entity

@OneToMany(cascade = CascadeType.ALL)
@JoinColumn(name="STUDENT_ID")
private List<Student> students;

如果您想使用您的模型,請嘗試在將大學設置為學生之前保存大學(因為在您的代碼中,您試圖兩次保存同一所大學,第一次使用 fstudent,第二次使用 fstudent1),在這種情況下,我建議您不使用級聯:

  University university = universityRepo.save(new University("MG", "India"));
    
    Student fstudent = new Student("Deeksha", "Sivakumar", "A", university);
    fstudent.setUniversity(university);
    studentRepo.save(fstudent);
    
    
    Student fstudent1 = new Student("Sivakumar", "Nair", "A", university);
    fstudent1.setUniversity(university);
    studentRepo.save(fstudent1);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM