![]() |
![]() |
-Code46- |
![]()
Post
#1
|
Goście ![]() |
Witam!
Wkońcu natrafiłem na problem dotyczący kasowania danych z bazy mysql. Temat dotyczy bardziej bazy niż php ale mam nadzieję, że mi pomożecie.. Mam kilka tabel. Kasując informacje z jednej, muszę usunąć odpowiednie dane z innych tabeli. Wiem, że instrukcji DELETE nie można użyć tak jak select. Dla każdej tabeli należy wywołać osobno instukcję DELETE. Poczytałem sobi o trancakcjach i blokowaniu ale nie wiem jak to zastosować w praktyce. Chodzi mi o to, że gdy skasuję z tablei kont użytkownika, a z drugiej tabeli (tam gdzie mam dane o użytkownikach) nie uda się skaować odpowiedniego wpisu (np z nieznanych przyczyn) to tabelę z kontami doprowadzę do stanu z przed wykonani instrukcji DELETE, po to aby baza się nie posypała. Jak to zrobić? |
|
|
![]() |
-Code46- |
![]()
Post
#2
|
Goście ![]() |
Cytat Ale typ powiazania ma byc CASCADE czyli.
Indeksy powinno sie stosowac gdzie dane powtarzaja sie mniej niz 20% Dziękuje za pomoc (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Zaraz sprawdze. Ale moim zdaniem lepsze będą transakcje. Bo przy takich rozwiązaniach, żęby usunąć login i hasło z tabeli konta, trzeba usuwać dane (imie, nazwisko, adres, itd) z drugiej tabeli żeby usunąć login i hasło. Moim zdaniem to jest trochę tak od "pupy strony". Nie przemyślane. Lepiej samemu wykonać 2x indstrukcje DELETE niż raz ale od tylca. Co Ty o tym myślisz? PS. W MySQL>4.0 tablice InooDB są domyślnie włączone Dziękuje za pomoc. |
|
|
![]() ![]() |
![]() |
Aktualny czas: 18.10.2025 - 13:12 |