首页 > 解决方案 > Hibernate 在数据库中创建冗余列

问题描述

我在一个房间管理软件上工作,我想知道某个建筑物的房间。

在建筑实体中的@OneToMany关系:

   @JsonBackReference(value= "room")
   @OneToMany(targetEntity=Room.class, mappedBy="building", fetch=FetchType.EAGER,cascade = 
              CascadeType.REMOVE,orphanRemoval = true)
   public Set<Room> getRooms() {
       return this.rooms;
}

在房间实体中的@ManyToOne关系:

@JsonManagedReference(value= "room")
@ManyToOne(fetch=FetchType.EAGER)
@JoinColumn(name="building_number", nullable=false)
@OnDelete(action = OnDeleteAction.CASCADE)
public Building getBuilding() {
    return this.building;
}

由于这些关系,自动生成的数据库会生成一个额外的字段,我只想将它们映射到 Room.building_number 上:

building_building_number,我只需要 building_number。

标签: javaspringhibernaterelationshiphibernate-mapping

解决方案


尝试使用类似的东西:

建筑类:

@OneToMany(mappedBy="building")
private Set<Room> rooms;

// getters and setters

房间等级:

@ManyToOne
@JoinColumn(name="building_number", nullable=false)
private Building building;

// getters and setters

推荐阅读