[英]JPA related entities persist
我为我的应用程序设计了一些表,在这些表中放置了以下内容:
product productversion
--- ---
productId productVersionId
productVersionId (ref) productId (ref)
name length
height
我们之间有一对多的关系。 我只需要一些基本参数,这些参数可以更改和版本化参数,以便可以查看其历史记录。 现在...我在保留这些对象方面遇到问题。 我尝试了多种方法,这是最古老的一种:
Product p = new Product();
p.name = "some name";
Productversion pv = new Productversion();
pv.length = 10;
pv.height = 20;
p.productversionId = pv;
但是,在尝试保留该对象时,我收到了一个错误消息,即productId不能为null,它指向Productversion对象中的productId字段。 我怎样才能做到这一点?
[更新]有关我的问题的更多信息:
public class Product implements Serializable {
@JoinColumn(name = "productversionId", referencedColumnName = "productversionId")
@ManyToOne(optional = true, cascade = CascadeType.PERSIST)
private Productversion productversionId;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "productId")
private Collection<Productversion> productversionCollection;
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Basic(optional = false)
@Column(name = "ProductId")
private Integer productId;
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 255)
@Column(name = "Name")
private String name = null;
// well I believe construct and getter/setter not important now
第二个实体:
public class Productversion implements Serializable {
@OneToMany(cascade = CascadeType.ALL, mappedBy = "productversionId")
private Collection<Productiondata> productiondataCollection;
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Basic(optional = false)
@Column(name = "productversionId")
private Integer productversionId;
@Basic(optional = false)
@NotNull
@Column(name = "parameter")
private float weight;
以及我创建新对象的方式(不知道如何执行此操作):
public Product getNewProduct() {
if (newProduct == null) {
this.newProduct = new Product();
Productversion pv = new Productversion();
pv.setProductId(newProduct);
newProduct.setProductversionId(pv);
}
return newProduct;
}
我试图持久化对象的方式:
public Boolean addEntry(Product productData) {
Boolean status = false;
DbConnector dc = new DbConnector();
EntityManager em = dc.getEntityManager();
try {
EntityTransaction et = em.getTransaction();
et.begin();
em.persist(productData);
et.commit();
status = true;
} finally {
em.close();
}
return status;
}
好像您在Product对象的id字段的集合中丢失了一样。
Product p = new Product();
p.id = 1; <<<<<<-------------------
p.name = "some name";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.