Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »David Malcolm se na blogu vývojářů Red Hatu rozepsal o vybraných novinkách v GCC 16, jež by mělo vyjít v nejbližších dnech. Vypíchnuta jsou vylepšení čitelnosti chybových zpráv v C++, aktualizovaný SARIF (Static Analysis Results Interchange Format) výstup a nová volba experimental-html v HTML výstupu.
Byla vydána verze R14.1.6 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.
Jon Seager z Canonicalu včera na Ubuntu Community Hubu popsal budoucnost AI v Ubuntu. Dnes upřesnil: AI nástroje budou k dispozici jako Snap balíčky, vždy je může uživatel odinstalovat. Ve výchozím nastavení budou všechny AI nástroje používat lokální AI modely.
Nový ovladač Steam Controller jde do prodeje 4. května. Cena je 99 eur.
Greg Kroah-Hartman začal používat AI asistenta pojmenovaného gkh_clanker_t1000. V commitech se objevuje "Assisted-by: gkh_clanker_t1000". Na social.kernel.org publikoval jeho fotografii. Jedná se o Framework Desktop s AMD Ryzen AI Max a lokální LLM.
Ubuntu 26.10 bude Stonking Stingray (úžasný rejnok).
Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.3.0. S experimentální podporou FLTK 1.4. S příkazem dilloc pro ovládání prohlížeče z příkazové řádky. Vývoj prohlížeče se přesunul z GitHubu na vlastní doménu dillo-browser.org (Git).
+----+------------+----------+----------+ | id | product_id | group_id | price | +----+------------+----------+----------+ | 61 | 3 | 0 | 100.00 | | 62 | 3 | 2 | 100.00 | | 6 | 4 | 0 | 10000.00 | +----+------------+----------+----------+A jde mi zde o sloupec group_id. Potřeboval bych z této tabulky dostat takové řádky, že pokud bude obsahovat pro jeden product_id jak řádek s group_id=0, tak i s group_id=2, tak aby mi to vrátilo řádek s group_id=2, ale pokud pro daný product_id bude jenom group_id=0, tak aby mi to vrátilo řádek s group_id=0. Zkoušel jsem už různé možnosti, ale nějak se mi nedaří přijít na to jak definovat WHERE podmínku. Předem děkuji za rady.
SELECT id, product_id, group_id, price FROM tabulka WHERE group_id=2 OR (group_id=0 AND NOT group_id=2)a toto mi to vyplivne:
+----+------------+----------+--------+ | id | product_id | group_id | price | +----+------------+----------+--------+ | 61 | 3 | 0 | 100.00 | | 62 | 3 | 2 | 100.00 | +----+------------+----------+--------+
-- existuje pouze radek s group_id = 0
select * from tabulka t
where group_id = 0
and not exists ( select 0 from tabulka
where product_id = t.product_id
and group_id != 0 )
union all
-- existuje group_id = 2 i group_id = 0 a chci dvojku
select * from tabulka t
where group_id = 2
and exists ( select 0 from tabulka
where product_id = t.product_id
and group_id = 0 )
nebo by sel pouzit outer join sam na sebe. Jsou i dalsi reseni, zalezi na tom co presne potrebujes, jestli te trapi vykon apod. Nejefektivnejsi casto byva spojeni s proceduralnim zpracovanim, pokud prichazi z hlediska aplikace v uvahu.
group_id nějakou konkrétní hodnotu a v případě absence se má použít group_id=0?
SELECT * FROM (SELECT * FROM tab ORDER BY group_id DESC) AS tab2 GROUP BY product_id;
SELECT COALESCE(t2.id, t1.id), t1.product_id, COALESCE(t2.group_id, t1.group_id), COALESCE(t2.price, t1.price) FROM tab t1 LEFT JOIN tab t2 ON (t1.product_id=t2.product_id AND t2.group_id=2) WHERE t1.group_id = 0;
SELECT * FROM tabulka WHERE
group_id = 2 OR
(group_id = 0 AND product_id NOT IN (SELECT product_id FROM tabulka WHERE group_id = 2))
Pokud bys chtěl řádek s nejvyšším groupid (obecnější řešení), tak
SELECT * FROM TABULKA WHERE (product_id, group_id) IN
(SELECT product_id , MAX(group_id) FROM tabulka GROUP BY product_id)
Tiskni
Sdílej: