Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Transakcje w mysql
Forum PHP.pl > Forum > Bazy danych > MySQL
Miklosz
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)
sniezny_wilk
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.
Miklosz
a jak przykładowo zapisać warunek w sql, że jeśli nie ma błędów to commit??
Crozin
  1. <?php
  2. mysql_query('START TRANSACTION;');
  3.  
  4. if(!mysql_query('Zapytanie #1')){
  5. //nie trzeba robic rollback'a bo nic jeszcze nie zmienilismy
  6. exit('bląd');
  7. }
  8.  
  9. if(!mysql_query('Zapytanie #2')){
  10. mysql_query('ROLLBACK');
  11. exit('blad');
  12. }
  13.  
  14. if(!mysql_query('Zapytanie #3')){
  15. mysql_query('ROLLBACK');
  16. exit('blad');
  17. }
  18.  
  19. mysql_query('COMMIT;');
  20. ?>
zzeus
AUTOCOMMIT musisz ustawić na 0
Miklosz
OK, dzięki za podpowiedzi, patent wg Crozin działa, ale podrąże jeszcze temat jeśli pozwolicie...
Czy można zapisać sprawdzaenie poprawności wykonywanych działań po stronie sql, nie angażując w to php?
Kurczę, naprawdę mało jest w sieci informacji o zaawansowanych funkcjach w mysql.
Czy mysql obsługuje taką składnię jak inne sql'e np. if ... ifnot... endif... else... itd.

Staram się ostatnio coraz więcej przesuwać z php do sql'a, podobno tak jest i wydajniej, i skrypty bardziej przejrzyste...

Jeszcze post scriptum dotyczące autocommita - z tego co czytam w manualu mysql polecenie "start transaction" automatycznie wyłącza autocommit, więc to co napisał zzeus jest zbędne - sprawdziłem winksmiley.jpg

Jeszcze raz dziękuję za dotychczasowe odpowiedzi!
osiris
Mozna. Tutaj link do tego co Ci potrzeba aby przeniesc powyzsza funkcje z php do sql: http://dev.mysql.com/doc/refman/5.0/en/sto...procedures.html
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.