1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Erro ao deletar Foreign Key usando Hibernate e MySQL

Estou com um problema ao deletar um objeto que tem referencia para outro objeto. Tenho uma uma tabela chamada 'FILME' que possui uma chave estrangeira chamada 'FORNECEDOR', ocorre o seguinte erro ao deletar um Filme:

Mensagem de Erro:

Caused by: com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Cannot delete or update a parent row: a foreign key constraint fails (`locasystem`.`filme`, CONSTRAINT `Fornecedor` FOREIGN KEY (`Fornecedor`) REFERENCES `fornecedor` (`ID`) ON DELETE NO ACTION ON UPDATE NO ACTION)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:931)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723)
    at com.mysql.jdbc.Connection.execSQL(Connection.java:3283)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1332)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1604)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1519)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1504)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:208)
    ... 79 more

Relacionamento da classe Filme com Fornecedor:

    @ManyToOne(cascade=CascadeType.ALL)
    @JoinColumn(name = "FORNECEDOR", referencedColumnName = "ID")
    public Fornecedor getFornecedor() {
        return fornecedor.get();
    }

Minha configuração no MySQL:

https://www.filepicker.io/api/file/RXMC4FQRwbVixCqaOtmw

Alguem sabe como resolver esse problema?

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags hibernate ou faça a sua própria pergunta.