Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Transakcje w mysql
Miklosz
post
Post #1





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 10.01.2008

Ostrzeżenie: (0%)
-----


Mam przykładową transakcję, jak z manuala

start TRANSACTION;
update u_glowne set wartosc = '407' where nr = '100';
update u_glowne set wartosc = '407' where nr = '999';
commit;

Jeśli właściwie zrozumiałem ideę transakcji, to w przypadku, kiedy pierwsze zapytanie wywali błąd (np. nie ma wiersza o nr =100), to drugie zapytanie nie powinno być realizowane. Tymczasem tak się nie dzieje...
Co może powodować problem??

Tabela InnoDB, wersja MySQL: 5.045, autocommit = 1

Przy okazji - polecenie SET AUTOCOMMIT = 0 nie zmienia wartości tej zmiennej :/ (pewnie uprawnienia użytkownika)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
sniezny_wilk
post
Post #2





Grupa: Zarejestrowani
Postów: 732
Pomógł: 80
Dołączył: 25.05.2005
Skąd: Szczecin

Ostrzeżenie: (0%)
-----


A ROLLBACK ? Teraz zawsze masz commit, bez względu na to co zrobisz. Na początku startujesz transkacje, potem odbierasz wyniki wszystkich query, w sensie sprawdzasz czy zawierają błędy, jeśli tak to robić rollback, jeśli nie to comit.
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 7.10.2025 - 12:10