Tengo el siguiente uno bastante simple de muchas relaciones:Hibernate no elimina los huérfanos en OneToMany
equipo tiene un conjunto de jugadores:
@Entity(name = "TEAM")
@Access(AccessType.PROPERTY)
public class Team{
private Integer id;
private String name;
private Set<Player> players ;
@Id
@Column(name = "id")
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name = "team_name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@OneToMany(cascade = {CascadeType.ALL},orphanRemoval=true)
@JoinColumn(name = "TEAM_ID")
public Set<Player> getPlayers() {
return players;
}
public void setPlayers(Set<Player> players) {
this.players = players;
}
}
Y tiene un nombre único Identificación del & cada jugador.
@Entity(name = "PLAYER")
@Access(AccessType.PROPERTY)
public class Player implements Serializable{
private int id;
private String name;
@Id
@Column(name = "id")
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Column(name = "player_name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public boolean equals(Object obj) {
return id == ((Player)obj).id;
}
@Override
public int hashCode() {
return id;
}
}
corro un código muy simple:
Team team = createTeam(3) // creates team with 3 players ids={1,2,3}
session.saveOrUpdate(team);
...
private Team createTeam(int players) {
Team team = new Team();
team.setName("Bears");
team.setId(1);
for(int i=1 ; i<=players; ++ i){
Player player = new Player();
player.setId(i);
player.setName("Player"+i);
team.addPlayer(player);
}
return team;
}
Y me sale el siguiente como se esperaba:
- Hibernate: seleccione team_.id, team_.team_name como team2_0_ de team_ EQUIPO donde team_.id =?
- Hibernar: selecciona player_.id, player_.player_name como player2_1_ de PLAYER player_ donde player_.id =?
- Hibernar: selecciona player_.id, player_.player_name como player2_1_ de PLAYER player_ donde player_.id =?
- Hibernar: selecciona player_.id, player_.player_name como player2_1_ de PLAYER player_ donde player_.id =?
- Hibernate: insertar en TEAM (TEAM_NAME, ID) valores
- Hibernate (?,?): Insertar en el reproductor (PLAYER_NAME, id) valores
- Hibernate (?,?): Insertar en Player (PLAYER_NAME, ID) values (?,?)
- Hibernate: insertar en los valores de PLAYER (player_name, id) (?,?)
- Hibernate: update PLAYER set TEAM_ID =? donde id =? Hibernar: ¿actualizar PLAYER establecer TEAM_ID =? donde id =? Hibernar: ¿actualizar PLAYER establecer TEAM_ID =? donde id =?
Luego, más tarde yo:
Team team = createTeam(2) // creates team with 2 player ids={1,2}
session.saveOrUpdate(team);
y esperar que los jugadores huérfanos que se eliminarán, pero me sale:
- Hibernate: seleccione team_.id, team_.team_name como team2_0_ del equipo team_ donde team_.id =?
- Hibernar: selecciona player_.id, player_.player_name como player2_1_ de PLAYER player_ donde player_.id =?
- Hibernar: selecciona player_.id, player_.player_name como player2_1_ de PLAYER player_ donde player_.id =?
- Hibernar: actualizar PLAYER establecer TEAM_ID = null donde TEAM_ID =?
- Hibernar: ¿actualizar PLAYER establecer TEAM_ID =? donde id =?
- Hibernar: ¿actualizar PLAYER establecer TEAM_ID =? donde id =?
Que deja al jugador huérfano (id = 3) desconectado pero no eliminado ... ¿Alguna idea de lo que hago mal?
¿Qué está haciendo el método 'createTeam()'? – dcernahoschi
crea un equipo con jugadores –
Puede estar relacionado o no pero lo probamos en HSQL –