Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL][PHP]transakcja i podwójne rekordy
Hobo
post 4.04.2011, 12:25:22
Post #1





Grupa: Zarejestrowani
Postów: 14
Pomógł: 0
Dołączył: 31.01.2011

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


witam,

mam taki frament kodu:
  1. $link_id=mysql_connect(serwer, user, pass);
  2. if (!$link_id) {
  3. die(sql_error());
  4. } else {
  5. mysql_query("start transaction",$link_id);
  6. $res1= mysql_query("insert into tab1 (id) values (null)",$link_id);
  7. $id=mysql_insert_id($link_id);
  8. $res2= mysql_query("insert into tab2 (id, id2) values (null, $id)",$link_id);
  9. if (!$res1 || !$res2){
  10. mysql_query("rollback",$link_id);
  11. }else{
  12. mysql_query("commit",$link_id);
  13. }
  14. mysql_close($link_id);

a problemy z nim mam dwa:
1. 'insert' dodają po 2 rekordy do tabeli
2. w moim rozumieniu transakcja to zespół instrukcji wykonanych jak jedna, czyli gdy którakolwiek instrukcja wykona się błędnie pozostałe instrukcje w transakcji nie zostaną zatwierdzone. w powyższym kodzie gdy jedna jest bledna to druga i tak sie wykonuje i wpisuje 2 rekordy do tabeli.

pomóżcie, bo oślepłem... brzydal.gif

Ten post edytował Hobo 4.04.2011, 12:26:23
Go to the top of the page
+Quote Post
skowron-line
post 4.04.2011, 12:43:40
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


Jeżeli masz typ tabel myisam to zmien je na innodb i poczytaj dlaczego powinieneś zmienić.

+

http://www.php.net/manual/en/function.mysql-query.php#76991

Ten post edytował skowron-line 4.04.2011, 12:46:26


--------------------
I'm so fast that last night I turned off the light switch in my hotel room and was in bed before the room was dark - Muhammad Ali.
Peg jeżeli chcesz uprawiać sex to dzieci muszą wyjść, a jeżeli chcesz żeby był dobry ty też musisz wyjść - Al Bundy.

QueryBuilder, Mootools.net, bbcradio1::MistaJam
http://www.phpbench.com/
Go to the top of the page
+Quote Post
Hobo
post 4.04.2011, 17:40:14
Post #3





Grupa: Zarejestrowani
Postów: 14
Pomógł: 0
Dołączył: 31.01.2011

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


fakt, było myisam - zmieniłem na innoDB, ale niczego to nie zmieniło: rekordy nadal podwójnie i gdy w jednej instrukcji wystąpi błąd druga wstawia rekord do tabeli.

Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 14.06.2025 - 23:49