OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.
Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.
R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.
IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.
Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.
Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.
Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.
Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.
Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.
Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.
tabulka 'reg' má sloupce id, temp a email $stmt = $pdo->prepare('UPDATE `reg` SET temp = ? WHERE email = ?'); $stmt->execute(array($temp, $email));a potřeboval bych nějak po provedení tohoto dotazu vrátit id toho řádku ve kterém se ten update provedl. Děkuji
id
pomocou SELECT `id` FROM `reg` WHERE email = ?
. A potom zmeniť temp
pomocou UPDATE `reg` SET temp = ? WHERE id = ?
.
SELECT FOR UPDATE
. Jinak se může záznam mezi SELECT
em a UPDATE
m nekontrolovaně změnit a UPDATE
pak aktualizuje špatný záznam.
V tom případě je ale potřeba použít SELECT FOR UPDATE
.
Jak to myslíte? nic nemůžu kolm toho najít.. díky
SELECT FOR UPDATE
zamkne příslušné řádky, takže je jiná transakce nemůže měnit. Když řádky nezamknete, může při souběhu transakcí dojít ke změně jiných dat, než jste čekal.
Transakce 1 | Transakce 2 SELECT id FROM table WHERE email = 'franta@novak.cz'; | -- id = 1 | | | UPDATE table SET email = 'hugo@boss.cz' WHERE id = 1; | UPDATE table SET temp = 123 WHERE id = 1; |V transakci 1 jste tedy změnil záznam s e-mailem
hugo@boss.cz
, přitom jste chtěl změnit záznam s e-mailem franta@novak.cz
.
UPDATE `reg` SET temp = ? WHERE email = ?
V mysql můžeš
UPDATE `reg` SET id = @id := id, temp = ? WHERE email = ?
a pak id zjistit SELECT @id
.
Portabilní verzi je přes zamykání (tzn. select id where .... for update a pak teprv updatnout dle id), jak píší předřečníci.
Pokud používáš postgresql, můžeš udělat:
UPDATE `reg` SET temp = ? WHERE email = ?
Předpokládám, že bylo myšleno
UPDATE `reg` SET temp = ? WHERE email = ? RETURNING id;
Tiskni Sdílej: