当前位置: 首页 > 知识库问答 >
问题:

对象引用未保存的瞬态实例 - 在刷新之前保存瞬态实例

拓拔欣嘉
2023-03-14

我有两个例子。一个是项目,一个是模块。< code >一对多关系。

@Entity
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@Table(name = "project", uniqueConstraints = { @UniqueConstraint(columnNames = { "name", "version" }) })
public class Project implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "name")
private String name;
@Column(name = "version")
private String projectVersion;
@Column(name = "description")
private String description;
@Column(name = "is_cartridge")
private boolean cartridge;
@Column(name = "manifest")
private String manifest;
@OneToMany(mappedBy = "project", cascade = CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name = "project_id")
private Set<Module> modules = new HashSet<Module>();

@Entity
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@Table(name = "module", uniqueConstraints = { @UniqueConstraint(columnNames = { "project_id", "name", "module_id" }) })
public class Module implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "name")
private String name;
@Column(name = "description")
private String description;
@Column(name = "module_id")
private String moduleId;
@Column(name = "version")
private String version;
@Column(name = "type")
private String type;
@Column(name = "resource")
private String resource;
@OneToOne
@JoinColumn(name = "default_language_id")
private Locality defaultLocality = new Locality();
@OneToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "project_id")
private Project project = new Project();
@OneToMany(mappedBy = "module", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
@JoinColumn(name = "module_id")
private Set<KeyValue> keyValues = new HashSet<KeyValue>();

我将模块设置到项目中。然后使用session.save(项目)。第一次,因为数据库中没有记录,所以项目和模块可以保存到数据库中。然而,第二次,因为我不需要创建新项目,我只创建新模块,然后将模块设置回项目。

发生异常。

对象引用未保存的瞬态实例 - 在刷新之前保存瞬态实例。

@Transactional
public Project save(Project project) {
    Session session = sessionFactory.openSession();
    try {
        Criteria criteria = session.createCriteria(Project.class).add(
                Restrictions.eq("name", project.getName()));
        List<Project> list = criteria.list();
        if (list.size() == 0) {
            Integer id = (Integer) session.save(project);
            project = get(id);
            return (project);
        } else {
            Project persistedModule = list.get(0).merge(project);
            session.update(persistedModule);
            session.flush();    **// Problem occurs in this line.**
            return (persistedModule);
        }
    } finally {
        session.close();
    }
}

有什么办法可以解决这个问题吗谢谢

共有1个答案

孟俊发
2023-03-14

您的映射是错误的:

  • 您的一侧有一个OneToOne,另一侧有一个OneToOne。它应该是OneToOne和ManyToOne。
  • 您是说OneToMore由模块中的项目字段映射,但您也指定了一个连接列。如果它是按产品映射的,那么产品定义了关联的映射方式。因此,您必须在OneToMore上没有@JoinCol的注释。

顺便说一句,您为其他关联重复了这些错误。

您还对附加的项目(称为< code>persistedModule,这使事情变得非常混乱)调用了< code>update(),因为它是前面的< code>merge()调用的结果。更新附加的对象是没有用的。已经附加了,所以没有理由再附加了。

我不确定这是否能解决您的问题,因为如果没有代码和堆栈跟踪,很难知道实际的问题是什么,但是我会从解决这些问题开始

 类似资料: