![]() |
![]() |
![]()
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) |
|
|
![]() |
![]()
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.
-------------------- DevBlog - http://www.bartekrogus.pl
|
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 9 Pomógł: 0 Dołączył: 10.01.2008 Ostrzeżenie: (0%) ![]() ![]() |
a jak przykładowo zapisać warunek w sql, że jeśli nie ma błędów to commit??
|
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
|
|
|
![]()
Post
#5
|
|
![]() Grupa: Zarejestrowani Postów: 441 Pomógł: 71 Dołączył: 3.09.2007 Skąd: wrocław Ostrzeżenie: (0%) ![]() ![]() |
AUTOCOMMIT musisz ustawić na 0
-------------------- |
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 9 Pomógł: 0 Dołączył: 10.01.2008 Ostrzeżenie: (0%) ![]() ![]() |
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 ![]() Jeszcze raz dziękuję za dotychczasowe odpowiedzi! |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 121 Pomógł: 15 Dołączył: 19.07.2007 Ostrzeżenie: (0%) ![]() ![]() |
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
|
|
|
![]() ![]() |
![]() |
Aktualny czas: 21.08.2025 - 08:20 |