Bylo vydáno OpenBSD 7.8. S předběžnou podporou Raspberry Pi 5. Opět bez písničky.
Valkey (Wikipedie) byl vydán v nové major verzi 9.0. Valkey je fork Redisu.
Byly publikovány informace o kritické zranitelnosti v knihovně pro Rust async-tar a jejích forcích tokio-tar, krata-tokio-tar a astral-tokio-tar. Jedná se o zranitelnost CVE-2025-62518 s CVSS 8.1. Nálezci je pojmenovali TARmageddon.
AlmaLinux přinese s verzí 10.1 podporu btrfs. XFS bude stále jako výchozí filesystém, ale instalátor nabídne i btrfs. Více informací naleznete v oficiálním oznámení.
Společnost OpenAI představila svůj vlastní webový prohlížeč ChatGPT Atlas. Zatím je k dispozici pouze na macOS.
Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.
Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.
Na Humble Bundle běží akce Humble Tech Book Bundle: All Things Raspberry Pi by Raspberry Pi Press. Se slevou lze koupit elektronické knihy od nakladatelství Raspberry Pi Press a podpořit Raspberry Pi Press, Raspberry Pi Foundation North America nebo Humble.
Přidaný režim autonomního řízení vozidel Tesla Mad Max je dostupný pro vybrané zákazníky v programu EAP (Early Access Program). Nový režim je na silnici agresivnější, častěji mění pruhy a ne vždy dodržuje rychlostní limity. Agentura JPP spekuluje, že v Česku by se mohl nový režim namísto Mad Max jmenovat Mad Turek...
Byla vydána nová verze 9.18 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Nově také pro NanoPi R3S, R3S LTS, R76S a M5. Přehled novinek v poznámkách k vydání.
function select($table, $array){ $a = implode(', ', array_keys($array)); $b = implode(', ', array_fill(0, sizeof($array), '=?')); $sql = 'SELECT '.$a.' FROM '.$table.' WHERE '.$b.' LIMIT 1'; $stmt = $pdo->prepare($sql); $stmt->execute(array_values($array)); }
function select($table, $array){ $a = implode(', ', array_fill(0, sizeof($array), '=?')); $sql = 'SELECT * FROM '.$table.' WHERE '.$a.''; $stmt = $pdo->prepare($sql); $stmt->execute(array_values($array)); return $stmt = fetchAll(PDO::FETCH_ASSOC); }takhle by to melo fungovat
$stmt->fetchAll(PDO::FETCH_ASSOC);
$sql = ...
si přidej
var_dump($sql);a sleduj, jaké SQL dotazy generuješ. Snad ti docvakne, v čem děláš chybu.
dibi::query("SELECT * FROM [whatever]")
$res = dibi::select('product_id')->as('id') ->select('title') ->from('products') ->innerJoin('orders')->using('(product_id)') ->orderBy('title') ->execute();...které dibi umí, ale já je nemám rád a nepoužívám je. Speciálně pro Kita zvýrazním: Špagety jsou jednou z variant zápisu, statický mód je jednou z variant použití. Plnohodnotné objekty jako výsledky dotazů jsou samozřejmě užitečné, ale to patří už spíše do modelové vrstvy a ano, modelová vrstva může interně používat například dibi (nebo třeba PDO), věc vkusu
$res
? Umí to něco nebo je to jen Messenger, ve kterém je veřejný atribut product_id
?
echo "Výsledkem je: $res";Používám to docela často, zejména pokud $res má složitější strukturu, například řádek tabulky nebo položka seznamu s odkazy.
$res = dibi::query('select id from products where name = %s', $name)->fetchSingle();Pokud je to více políček, už musíš mít nějaké pravidlo, jak to převést na string, třeba tím, že si vytvoříš vlastní Row, třeba MyRow, která dědí od DataRow, definuješ ji metodu __toString() a nastavíš ji jako třídu pro výsledek:
class MyRow extends DibiRow { public function __toString() { $res = ""; foreach($this as $name => $value) { $res .= "$name: $value
"; } return $res; } } $res = dibi::query('select * from products where name = %s', $name)->setRowClass('MyRow')->fetch(); echo $res;
dibi::query('UPDATE `table` SET `text`=%s', $text, 'WHERE flag=%i', $flag);která je IMHO velmi návyková a pohodlná. Navíc to, že je dibi jistá (velmi primitivní - což je dobře!) mezivrstva velmi pomáhá tomu, kdyby náhodou někdy přecházel na jinou databázi. Výkonostně tu žádné měřitelné ztráty nejsou (bavíme se o tomto módu, ne o těch objektových špagetách). Niméně i v tomhle "array" módu umí dibi velmi užitečná kouzla, například:
dibi::query('UPDATE `table` SET ', array('attribut1' => 'foo', 'atribut2' => 'bar'));
$update = $db->prepare("UPDATE `table` SET `text`=? WHERE flag=?"); $update->execute(array($text, $flag)); $druhy_update = $db->prepare("UPDATE `table` SET `attribut1`=?, `attribut2`=?"); $druhy_update->execute(array('foo', 'bar'));a protože to mám ukryto v objektech modelu, které se o danou relaci starají, tak ani nevadí, že je to na dvou řádcích. Třída zůstává miniaturní.
dibi::query('SELECT * FROM `table` WHERE %and', array( array('number > %i', 10), array('number < %i', 100), ));
dibi::query('SELECT * FROM `table` WHERE %and', [ ['number > %i', 10], ['number < %i', 100], ]);
$options = array( 'driver' => 'mysql', 'host' => 'localhost', 'username' => 'root', 'password' => '***', 'database' => 'table', ); // v případě chyby vyhodí DibiException $connection = new DibiConnection($options); $connection->query('TRUNCATE `table`');A já sám DI s dibi normálně používám. A kdyby sis otevřel ten tutoriál, tak tenhle kód najdeš úplně nahoře. Ale ne, pán si to nerozklikne, aby se mu náhodou nerozbila jeho pravda o tom, jak je dibi hrozné a radši na něj bude plivat a ze sebe dělat akorát...
Tiskni
Sdílej: