Diskuze: Vnořená transakce
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Transactions cannot be nested. This is a consequence of the implicit commit performed for any current transaction when you issue a START TRANSACTION statement or one of its synonyms.
Zdroj: http://dev.mysql.com/…-commit.html
Na tvojom mieste by som upravil script tak, ze najskor prebehnem vsetky kola a do a do noveho pola ulozil len objekty ktore ti vyhovuju. Potom by som v novom cykle poukladal do DB.
Nedá se říct, že bych to potřeboval. Spíš to, že může nastat
situace, že by aplikace žádala otevření další transakce. Když budu
chtít ukládat Auto->uloz();, (např. poté, co ho naparsuju ze souboru
včetně Kol), tak musí celé ukládání proběhnout jako transakce kvůli
konzistenci dat, pochopitelně. Ovšem může nastat situace, kdy budu chtít
uložit jen Kolo->uloz();, protože jen u jednoho kola jsem měnil letní
gumu za zimní. I takové ukládání musí proběhnout jako transakce.
Zatím nad tím přemýšlím jen teoreticky. Nicméně jsem dospěl k (snad)
elegantnímu řešení. Transakci otevírá a zavírá statický
Repository::start_transakce();, Repository::commit();,
Repository::rollback();. Ukládá si počet požadavků na otevření a
zavření transakce. Pokud to není první žádost o otevření, nic nedělá,
jen si uloží self::$transaction++;. Při žádosti o zavření transakce
$transaction snižuje o 1 a pokud se dostane na 0, tak skutečně provádí
uzavření.
Při tomhle postupu nemusí zajímat při volání Kolo->uloz();, jestli
náhodou neotevíralo Auto transakci. Prostě požádá Repository o otevření,
provede uložení, požádá Repository o zavření a navrací true/false.
Auto->uloz(); pak na základě úspěchu svých dotazů a na základě
navrácených hodnot z každého Kolo->uloz(); rozhodne, jestli chce po
Repository commit nebo rollback.
Snad je to srozumitelné a není to úplná blbost .
znie to ako riesenie ktore by mohlo fungovat. Skus a daj nam vediet.
Zobrazeno 6 zpráv z 6.