Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Obsługa transakcji przez PHP, MySQL, ale niekoniecznie
ktuvok
post
Post #1





Grupa: Zarejestrowani
Postów: 243
Pomógł: 0
Dołączył: 30.11.2003

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


Mam skrypt o następującej konstrukcji:
  1. <?php
  2.  
  3. $SQL1 = &#092;"INSERT INTO ...\";
  4. $SQL2 = &#092;"UPDATE ...\";
  5. $SQL3 = &#092;"UPDATE ...\";
  6.  
  7. $Zacznij = mysql_query(&#092;"BEGIN;\");
  8. $Operacja1 = mysql_query($SQL1);
  9. $Operacja2 = mysql_query($SQL2);
  10. $Operacja3 = mysql_query($SQL3);
  11.  
  12. if (!mysql_error())
  13. {
  14. //Nie ma błędu, zatwierdzam transakcję
  15. $Wykonaj = mysql_query(&#092;"COMMIT;\");
  16. }
  17. else
  18. {
  19. $TrescBledu = mysql_error();
  20. //Wystąpił błąd bazy MySQL:
  21. $Wykonaj = mysql_query(&#092;"ROLLBACK;\");
  22. echo &#092;"Wystąpił następujący błąd bazy danych: $TrescBledu\";
  23. }
  24.  
  25. ?>

Czy taka konstrukcja jest poprawna?

Chodzi mi o to, czy jeśli błąd wystąpi na etapie Operacji1, a Operacja2 i
Operacja3 się powiodą, to czy mysql_error() również zwróci kod błędu?

Ewentualnie - jak inaczej to oprogramować?

I druga rzecz... Transakcja jest traktowana przez bazę w kontekście aktualnego identyfikatora połączenia z bazą, prawda? Ale którego? Każdy mój juzer łączy się z bazą z użyciem (z punktu widzenia bazy) tego samego loginu i hasła. W rezultacie zapytanie o CONNECTION_ID() daje za każdym razem inny rezultat, ale:
  1. <?php
  2.  
  3. $connection = mysql_connect(&#092;"host\", \"juzer\", \"hasło\");
  4.  
  5. ?>

zwraca mi w każdym przypadku Resource id #2 - dlaczego? Czy mogę w ten sposób bezpiecznie używać transakcji, nie martwiąc się, ze jeden juzer wycofa transakcję drugiego?

Pozdrawiam,
K
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Kinool
post
Post #2





Grupa: Zarejestrowani
Postów: 560
Pomógł: 0
Dołączył: 15.07.2003
Skąd: Kwidzyn

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


nawiazanie polaczenie poprzez wywolanie skryptu twozy inny identyfikator polaczenia pomimo ze uzywasz tych samych danych do polaczenia, jedynie jesli w skrypcie po raz kolejny bedziesz chcial nawiazac polaczenie a wczesniej nie zostanie ono zamkniete to manual mowi wyraznie:
Cytat
Przy drugim wywołaniu mysql_connect() z tymi samymi argumentami, nie będzie nawiązywane nowe połączenie, lecz zwrócony zostanie identyfikator już otwartego połączenia. Argument


co do obslugi sesji ja stosuje cos takiego:

wynik kazdego zapytania dodaje do tablicy np.
  1. <?php
  2. $queries[] = $sql->query('INSERT ...');
  3. ?>

jesli gdzies wynikl blad to w tablicy bedzie gdzies false

potem przed zaakceptowaniem trasakcji daje do sprawdzenie czy w tablicy jest false:
  1. <?php
  2.  
  3. if(in_array(false, $queries))
  4. {
  5.  $sql->query('ROLLBACK'); // gdzies wysapil blad wiec wycofujemy
  6. } else {
  7.  $sql->query('COMMIT'); // nie bylo bledu wiec akceptujemy
  8. }
  9.  
  10. ?>

moze robie to zle ale tak soie to wykombinowalem i z tego co sprawdzalem to dziala poprawnie

Ten post edytował Kinool 17.05.2005, 12:57:54
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: 3.10.2025 - 03:01