【问题标题】:Hibernate doesn't fill second table when one-to-one mapping is performed执行一对一映射时,Hibernate 不会填充第二个表
【发布时间】:2017-02-09 15:54:42
【问题描述】:

我有一个小型应用程序,负责将数据保存在数据库中。我为此使用Hibernate。以下是我的代码:

用户类

@Entity
@Table(name = "USERS")
@Transactional
public class User implements Serializable{

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "USER_ID")
private int userId;

@Column(name = "FIRST_NAME")
private String firstName;

@Column(name = "SURNAME")
private String surname;

@Column(name = "AGE")
private int age;

@Column(name = "EMAIL")
private String email;

@OneToOne(fetch = FetchType.LAZY, mappedBy = "user", cascade = CascadeType.ALL)
private Address address;

public User() {

}

public User(String firstName, String secondName, int age, String email) {
    this.firstName = firstName;
    this.surname = secondName;
    this.age = age;
    this.email = email;
}

// GETTERS/SETTERS

地址类

@Entity
@Table(name = "ADDRESS")
@Transactional
public class Address implements Serializable{

/**
 * 
 */
private static final long serialVersionUID = 1L;

@GenericGenerator(name = "generator", strategy = "foreign", parameters = @Parameter(name = "property", value = "user"))
@Id
@GeneratedValue(generator = "generator")
@Column(name = "USER_ID", unique = true, nullable = false)
private int addressId;

@Column(name = "STREET")
private String street;

@Column(name = "STREET_NUMBER")
private String streetNumber;

@Column(name = "FLAT_NUMBER")
private String flatNumber;

@Column(name = "POSTAL_CODE")
private String postalCode;

@Column(name = "CITY")
private String city;

@Column(name = "COUNTRY")
private String country;

@OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@PrimaryKeyJoinColumn(name = "USER_ID")
private User user;


public Address() {

}

public Address(String street, String streetNumber, String flatNumber, String postalCode, String city, String country) {
    this.street = street;
    this.streetNumber = streetNumber;
    this.flatNumber = flatNumber;
    this.postalCode = postalCode;
    this.city = city;
    this.country = country;
}

//GETTERS/SETTERS

当我执行负责在这两个表中保存数据的save() 方法时,只有用户表被填满。

我找到了这个解决方案Hibernate @OneToOne with Shared Primary Key(bidirectional). Dependent entity not persisted in DB.

但这对我不起作用。

我正在使用:

  • 休眠 4.3.6.Final
  • Spring 4.3.6.RELEASE

【问题讨论】:

    标签: java spring hibernate jpa one-to-one


    【解决方案1】:

    您的 Address 类应编码如下(假设 Address 应使用与生成 id 的 User 相同的 Id 创建):

    @Id
    @Column(name = "USER_ID", unique = true, nullable = false)
    private int addressId;
    
    
    @MapsId
    @OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
    @JoinColumn(name = "USER_ID", referencedColumnName = "USER_ID")
    private User user;
    

    持续期间

    User u = new User();
    // populate u fields
    
    Address a = new Address();
    a.setUser(u);
    // populate a fields
    
    session.persist(a);
    

    【讨论】:

    • 太棒了。很高兴我能帮上忙
    猜你喜欢
    • 2013-11-12
    • 2011-04-18
    • 2021-08-18
    • 2012-04-21
    • 1970-01-01
    • 2022-11-26
    • 1970-01-01
    相关资源
    最近更新 更多