Ir para o conteúdo
  • Revista PROGRAMAR: Já está disponível a edição #60 da revista programar. Faz já o download aqui!

t0ze

[Resolvido] Apagar chaves estrangeiras - (quando a primeira é apagad

Mensagens Recomendadas

t0ze

Bom dia,

Estou na duvida de que forma é q poderei apagar todos os registos com um ID especifico. Para melhor explicar isto, deixo o meu cenário.

Tabela principal

*REGISTO

ID (PK)

NOME

depois associado a este registo existem tabelas auxiliares

*Mensagem

ID(PK)

Assunto

IDRegisto (FK) <---

Historico

ID (PK)

Acao

IDRegisto (FK)

A dúvida é: O que devo fazer (configuração MYSQL ou outras) para que ao apagar na tabela principal o ID (PK) apague nas outras tabelas o IDRegisto (FK).

Obrigado

Editado por t0ze

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pmg

O comando DELETE serve para isso mesmo ...

delete from tabelaprincipal where registo = 42


What have you tried?

Não respondo a dúvidas por PM

A minha bola de cristal está para compor; deve ficar pronta para a semana.

Torna os teus tópicos mais atractivos e legíveis usando a tag CODE para colorir o código!

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

podes criar uma funcao para quando apagares um registo ele va' 'as tabelas que contem a chave externa e apagalas

  • Voto 1

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
brunoais

Não chega fazer um constraint de CASCADE para qd a linha é apagada?


"[Os jovens da actual geração]não lêem porque não envolve um telecomando que dê para mirar e atirar, não falam porque a trapalhice é rainha e o calão é rei" autor: thoga31

Life is a genetically transmitted disease, induced by sex, with death rate of 100%.

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pmg

Vê a resposta abaixo (post #7), do jsWizard.

Um trigger é uma má solução.

Deixo ficar a minha resposta original para documentação.


Podes, talvez, criar um TRIGGER

mysql> delimiter @
mysql> create trigger apagaregisto before delete on registo
   -> for each row begin
   ->     delete from mensagem where idregisto = old.id;
   ->     delete from historico where idregisto = old.id;
   -> end@
mysql> delimiter ;

Depois, ao apagar na tabela registo, o trigger automagicamente apaga nas outras tabelas.

Atenção, que assim (com qualquer solução automática) perdes a segurança que tinhas em que o sistema te impede de apagar coisas que são usadas noutro lado. Mas se é mesmo isso que pretendes ...

Editado por pmg
trigger testado; ver post #7
  • Voto 1

What have you tried?

Não respondo a dúvidas por PM

A minha bola de cristal está para compor; deve ficar pronta para a semana.

Torna os teus tópicos mais atractivos e legíveis usando a tag CODE para colorir o código!

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
jsWizard

na FK defines:

... ON DELETE CASCADE...

se apagares o registo "PAI" então os registos "FILHOS" serão também automaticamente apagados.

cuidado com o uso do DELETE CASCADE.. se tiveres DELETE CASCADE em todas as FKs.. ao apagar um registo podes estar a apagar registos em muitas tabelas. Portanto isto deve ser usado sempre que necessário.. mas não devem ser criadas FKs com DELETE CASCADE "à toa" :D

http://dev.mysql.com/doc/refman/5.5/en/innodb-foreign-key-constraints.html

Não deves implementar nenhum trigger.. para quê desenvolver um trigger para implementar uma funcionalidade que a BD já disponibliza nativamente??

inté!

Editado por jsWizard
  • Voto 2

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites

Crie uma conta ou ligue-se para comentar

Só membros podem comentar

Criar nova conta

Registe para ter uma conta na nossa comunidade. É fácil!

Registar nova conta

Entra

Já tem conta? Inicie sessão aqui.

Entrar Agora

×

Aviso Sobre Cookies

Ao usar este site você aceita os nossos Termos de Uso e Política de Privacidade. Este site usa cookies para disponibilizar funcionalidades personalizadas. Para mais informações visite esta página.