JPA merge() não funciona como esperado quando se salva um objeto modificado

votos
47

Este é o meu cenário para a entidade..

@Entity
@Getter
@Setter
@Table(name = movies, schema = public)
public class Movie {
    @Id
    @Column(name = id)
    private UUID movieId;

    @OneToMany(mappedBy = actor, fetch = FetchType.EAGER, cascade = CascadeType.ALL)
    private Set<Actors> actors = new HashSet<>();

    //Getters and setters
    }
}
@Entity
@Getter
@Setter
@Table(name = actors_movies, schema = public)
public class ActorMovie {

    @EmbeddedId
    private ActorId id;

    @ManyToOne(fetch = FetchType.LAZY)
    @MapsId(movieId)
    @JoinColumn(name = id_movie_movie)
    private Movie movie;

    //Getters and setters below
}

Eu sou capaz de chamar o entityManager.merge()' when I add a newActor` com sucesso para a lista de filmes. O seguinte persiste com sucesso nas tabelas.

Movie movie = getMovieById(id);
movie.setActors(new Actor());
entityManager.merge(movie);

Depois quero actualizar o nome do actor, por isso o que faço é isto. Eu NÃO sou capaz de atualizar um Ator já persistente/existente:

Movie movie = getMovieById(id);
movie.getActors().get(0).setName(New Name);
entityManager.merge(movie);

O acima não funciona, eu posso ver o objeto sendo atualizado em modo de depuração, mas quando merge()é chamado ele não atualiza a base de dados.

Onde é que eu estou a ir errado? Pensei que a fusão actualizaria se já existisse

Publicado 06/06/2020 em 03:21
fonte usuário
Em outras línguas...                            

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more