看看以下类(单向@OneToMany)
@Entity
public class Team {
private Integer id = -1;
@Id
@GeneratedValue
public Integer getId() {
return this.id;
}
private List<Player> playerList;
@OneToMany
@Cascade(CascadeType.SAVE_UPDATE)
@JoinColumn(name="TEAM_ID", insertable=false, updateable=false)
public List<Player> getPlayerList() {
return this.playerList;
}
public void addPlayer(Player player) {
player.setId(new PlayerId(getId(), getPlayerList().size()));
playerList.add(player);
}
}
注意 addPlayer: 团队的 id 和玩家的团队 ID 引用同一个实例,所以
AssertEquals(team.getId(), player.getPlayerId().getTeamId());
应该工作,不是吗?
Hibernate 不会保存 -1 值,因为我已经声明了生成器策略(默认为 auto) 如果声明了标识符生成器,Hibernate 会处理主键值分配。我已将 -1 分配给团队的 id,以便在玩家的 id 中共享其引用(调用 addPlayer 方法时),如下所示
@Embeddable
public class PlayerId implements Serializable {
private Integer teamId;
private Integer playerIndex;
// required no-arg constructor
public PlayerId () {}
public PlayerId(Integer teamId, Integer playerIndex) {
this.teamId = teamId;
this.playerIndex = playerIndex;
}
@Column(name="TEAM_ID", nullable=false)
public Integer getTeamId() {
return this.teamId;
}
@Column(name="PLAYER_INDEX", nullable=false)
public Integer getPlayerIndex() {
return this.playerIndex;
}
// getters and setters
public boolean equals(Object o) {
if(o == null)
return false;
if(!(o instanceof PlayerId))
return false;
PlayerId other = (PlayerId) o;
if(!(getTeamId().equals(other.getTeamId()))
return false;
if(!(getPlayerIndex().equals(other.getPlayerIndex()))
return false;
return true;
}
}
但是当我打电话时(特别看一下addPlayer)
Team team = new Team();
Player player = new Player();
// teamId property in PlayerId references Team id
team.addPlayer(player);
session.save(team);
我看到了我得到的数据库
PLAYER
TEAM_ID PLAYER_INDEX
-1 0
TEAM
ID
1
当我保存后比较时
AssertEquals(team.getId(), player.getPLayerId().getTeamId()); // It does not works! why ?
日志输出
INSERT INTO TEAM VALUES()
// SELECT BEFORE SAVING OR UPDATING WHEN USING A COMPOUND PRIMARY KEY
SELECT * FROM PLAYER WHERE TEAM_ID = ? AND PLAYER_INDEX = ?
INSERT INTO PLAYER (TEAM_ID, PLAYER_INDEX) VALUES (?, ?)
那么你知道为什么 Hibernate 在保存了一个团队和它的玩家之后,在 Player 的 teamId 属性中丢失了 Team 的 id 引用吗?