1.生成框架时有没有改变domain中一对一的两个表的配置:
正确的方式是:例如project的id和projectArtical中的projectId相关联,而project是主表,projectArtical是从表,
而project的id配置和关联关系的配置要改成如下:
@Column(name = "ID", nullable = false)
@Basic(fetch = FetchType.EAGER)
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@XmlElement
Integer id;
/**
*/
@OneToOne(mappedBy = "project", fetch = FetchType.LAZY)
@XmlElement(name = "", namespace = "")
ProjectArtical projectArtical;
projectArtical的projectId的配置和关联关系的配置改成如下:
@Column(name = "Project_ID", nullable = false)
@Basic(fetch = FetchType.EAGER)
@Id
@XmlElement
Integer projectId;
切记要把用MyEclipse for Spring10.6自动生成的
@PrimaryKeyJoinColumn
@OneToOne(fetch = FetchType.LAZY)
@XmlElement(name = "", namespace = "")
Project project;
@OneToOne(fetch = FetchType.LAZY)
@JoinColumns({ @JoinColumn(name = "Project_ID", referencedColumnName = "ID") })
@XmlElement(name = "", namespace = "")
Project project;
2.在保存一对一个的表,两表先后保存时,必须先保存主表然后保存副表,在保存主表的同时,必须先将主表的副表给先设置为空,例如project.setProjectArtical(null); 然后再保存projectArtical表。
然而在删除的时候必须先删除projectArtical表,再来删除project表。