Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.
Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.
Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.
Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.
Byla vydána nová verze 10.1 sady aplikací pro SSH komunikaci OpenSSH. Uživatel je nově varován, když se nepoužívá postkvantovou výměnu klíčů.
Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.
Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.
Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.
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: