@OneToOne 使用注释休眠。无法正确保存



我不能让我的外键自动生成使用hibernate和jpa注释。一切似乎都很好,条目保存在数据库中。所有的数据都来自一个表单,当提交时,它创建一个带有ModelAttribute的User对象,然后将其保存在Database中。这是我的豆子。还有什么需要我补充的吗?

@Entity
@Table(name="adress")
public class Adress implements Serializable {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="adress_id")
private Integer adressId;
@NotBlank(message="The city must be completed")
@Column(name="city")
@Size(min=5,max=30)
private String city;
@NotBlank(message="The street must be completed")
@Column(name="street")
@Size(min=5,max=30)
private String street;
@NotNull(message="The street number must be completed")
@NumberFormat
@Column(name="street_no")
private Integer streetNo;
@OneToOne
@JoinColumn(name="user_id")
private User user;}

和另一个:

@Entity
@Table(name="users")
public class User implements Serializable {
@Id
@Column(name="user_id")
@GeneratedValue(strategy=GenerationType.AUTO)
private Integer userId;
@NotBlank(message="Username can't be blank")
@Size(min=5,max=30)
@Column(name="username")
private String username;
@NotBlank(message="Password field can't be blank")
@Size(min=5,max=30)
@Column(name="password")
private String password;
@NumberFormat
@NotNull(message="Age field must not be blank")
@Column(name="age")
private Integer age;
@Column(name="message")
@Size(min=0,max=100)
private String message;
@Column(name="date")
@DateTimeFormat(pattern="dd/mm/yyyy")
private Date dateCreated;
@OneToOne(mappedBy="user",cascade=CascadeType.ALL,fetch=FetchType.EAGER)
private Adress adress;

+它们的getter和setter

public void save(T entity){
    sessionFactory.getCurrentSession().save(entity);
}

如果我理解正确,并且您正试图让Hibernate在相关记录上设置外键,这可能会有所帮助。尝试去掉mapappedby,代之以指定JoinColumn。这对我来说是一对多:

:

@Entity
@Table(name = "`order`")
public class Order implements Serializable {
@Id
@GeneratedValue
private Long id;
// Order columns...
@OneToMany(cascade = CascadeType.ALL)
@JoinColumn(name = "order_id")
private Set<Item> items;
}

单品:

@Entity
@Table(name = "item")
public class Item implements Serializable {
@Id
@GeneratedValue
private Long id;
// Item columns...
@ManyToOne(optional = false)
@JoinColumn(name = "order_id", referencedColumnName = "id", nullable = false)
private Order order;
}

地址类

 @OneToOne(mappedBy="adress")
private User user;

和用户类

@OneToOne(cascade=CascadeType.ALL,fetch=FetchType.EAGER,optional=false)
@PrimaryKeyJoinColumn
private Adress adress;

相关内容

最新更新