Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak używać usuwania kaskadowego w silniku pamięci masowej MySQL MyISAM?

Tak. Po prostu nie możesz z tym silnikiem.

edytować. Możesz napisać wyzwalacz, który po usunięciu rekordu ze swojej tabeli usuwa wszystkie rekordy podrzędne we wszystkich innych tabelach.

Ok. Napisałem ci przykład:

 create table tab1 (
 id int )
 engine = myisam;

insert into tab1 values (1),(2),(3),(4); 

 create table tab2(
 id int not null auto_increment primary key,
 id_tab1 int
 ) engine = myisam;

 insert into tab2 (id_tab1) values (1),(2),(2),(3),(4);

 create table tab3(
 id int not null auto_increment primary key,
 id_tab1 int
 ) engine = myisam;

  insert into tab3 (id_tab1) values (1),(2),(2),(3),(2);


delimiter //
create trigger deletecascade after delete on tab1
for each row
begin
delete from tab2 where id_tab1 = old.id;
delete from tab3 where id_tab1 = old.id;
end; //
delimiter ;

delete from tab1 where id = 2;

Mam nadzieję, że to pomoże.

edytować. Oczywiście działa to nawet jeśli usuniesz więcej id z tabeli 1 w tym samym czasie:

delete from tab1 where id in (2,3,4);



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL:Porównaj MIĘDZY czasem

  2. PHP mySQL — czy możesz zwrócić powiązaną tablicę z indeksem liczbowym?

  3. Nieprawidłowa precyzja dziesiętna MySQL i PHP

  4. Przykłady LOCALTIME – MySQL

  5. Lista specyfikatorów formatu daty MySQL