Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.
Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si
… více »Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).
Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.
V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.
Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.
Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.
Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
SELECT A.name, A.id, B.popis, C.url, A.adresa, A.trieda FROM tab1 A, tab2 B, tab3 C WHERE A.top_id = '8930440' AND A.id=B.id AND A.id=C.id AND B.popistyp_id=11 AND (B.language='sk' OR B.language='en') GROUP BY A.id ORDER BY B.language='sk' DESCA.id, B.id a C.id je index, taktiež A.top_id je index, B.language je index a A.top_id je index. B.popis typ je text. B.popistyp_id nie je index, keďže mohutnosť je len 12, ale skúsil som dať aj index, no výsledok je rovnaký. tab2 má okolo 3 mil. záznamov Vykonanie dotazu trvá prvý krát niekoľko sekúnd, potom už ide rýchlo, čiže druhý, tretí atď to už nabehne okamžite. Ak ho však zadám po polhodine, zase prvý krát to trvá veľmi dlho, potom to už ide rýchlo. Neviete prosím poradiť, ako by som to mohol zrýchliť? A čo je vlastne príčinou toho, že prvý krát to ide pomaly a potom už rýchlo? Vopred ďakujem za info.
EXPLAIN SELECT ...
- to by Ti malo napovedať, či sa naozaj používajú indexy tam kde sa majú, alebo či ich treba vytvoriť / zmeniť / analyzovať (príkaz ANALYZE
). Takto od pása by som ale tipoval, že pri prvom selecte sa to načítava z disku, preto to trvá dlhšie. Pri ďalších selectoch to potom už je v cache a ide to rádovo rýchlejšie. Ak sa to chvíľu nepoužíva, tak cache sa naplní inými vecami a zase sa to spomalí. Pomôže pridať do stroja viac RAM, ale ak sa jedná o naozaj veľkú databázu, tak potom už len optimalizovať aplikáciu.
id select_type table type possible_keys key key_len ref rows Extra 1 SIMPLE A ref top_id, id top_id 4 const 636 Using temporary; Using filesort 1 SIMPLE C ref id id 4 test.A._id 1 1 SIMPLE B ref id,language id 4 test.A._id 35 Using whereTakže v A tabulke mám použiť spoločný index pre top_id a id? Ja používam index pre top_id a id na každé samostatne.
WHERE
) na velkých datech (statisíce až miliony řádku v několika tabulkách) bylo docela o dost pomalejší než použití klausule JOIN
a potvrdilo se to i na M$SQL(už ale nevím verzi) i když tam byl rozdíl výrazně nižší.WHERE
se vytvoří data na vše a pak se omezují a při JOINování dochází k postupné redukci dat, tudíž to nemá takové paměťové nároky.SELECT A.name, A.id, B.popis, C.url, A.adresa, A.trieda FROM tab3 AS C LEFT JOIN tab1 AS A ON A.id=C.id AND A.top_id = '8930440' LEFT JOIN tab2 AS B ON B.id=C.id AND B.popistyp_id=11 WHERE (B.language='sk' OR B.language='en') GROUP BY A.id ORDER BY B.language='sk' DESC
CREATE TABLE `tab3` ( `id` int(16) NOT NULL default '0', `url` varchar(255) default NULL, KEY `id` (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
CREATE TABLE `tab2` ( `popis` text, `popistyp_id` int(6) NOT NULL default '0', `id` int(16) NOT NULL default '0', `language` char(2) default NULL, KEY `id` (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
CREATE TABLE `tab1` ( `adresa` varchar(255) default NULL, `top_id` int(16) NOT NULL default '0', `trieda` char(2) default NULL, `id` int(16) NOT NULL default '0', `name` varchar(255) default NULL, KEY `top_id` (`top_id`), KEY `id` (`id`), KEY `name` (`name`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
UNIQUE
či PRIMARY
ORDER BY
, má být opravdu na pravdivostní hodnotu ?, dal bych tam jen ORDER BY B.language DESC
nebo ORDER BY B.language ASC
Takže asi takto:SELECT DISTINCT A.name, A.id, B.popis, C.url, A.adresa, A.trieda FROM (SELECT * FROM tab1 WHERE top_id = '8930440') AS A INNER JOIN tab2 AS B ON A.id = B.id AND B.popistyp_id =11 AND B.language IN ('sk', 'en') INNER JOIN tab3 AS C ON A.id = C.id ORDER BY B.language DESCČekal bych vyšší výkon ale nevím (no a pak ještě doladit indexi podle
EXPLAIN
).
DISTINCT
navíc.
SELECT DISTINCT A.name, A.id, B.popis, C.url, A.adresa, A.trieda FROM (SELECT DISTINCT name, id, adresa, trieda FROM tab1 WHERE top_id = '8930440') AS A INNER JOIN tab2 AS B ON A.id = B.id AND B.popistyp_id =11 AND B.language IN ('sk', 'en') INNER JOIN tab3 AS C ON A.id = C.id ORDER BY B.language DESC
SELECT A.name, A.id, B.popis, C.url, A.adresa, A.trieda FROM tab1 A JOIN tab2 B ON B.id = A.id JOIN tab3 C ON C.id = A.id WHERE A.top_id = 8930440 AND B.popistyp_id=11 --AND (B.language='sk' OR B.language='en') --hezci a jednoduseji modifikovatelna je podle me klauzule in AND B.language IN ('sk', 'en') GROUP BY A.id ORDER BY B.language='sk' DESCJestli je klauzule join rychlejsi nez spojeni omezene v klauzuli where se rika, ze by to melo byt vykonove stejne (resp. parser by to mel chapat jako stejny vyraz) a jestli ne, tak se jedna o bug. Nicmene joiny jsou pro spoustu lidi prehlednejsi a v pripade jejich pouziti te syntakticka kontrola nepusti pres opomenute vyjadreni relace...
INNER JOIN
to tak bude. S provádením LEFT a RIGHT JOINU, už to ale bude jinak (nehledě na to že LEF a RIGHT mohou mít na některých enginech rozdílný výkon).
Pozn. na PostrgeSql, jsem četl, že rychlost přes WHERE a JOIN je za ideálních podmínek identická, což už samo o sobě vzbuzuje oprávněnou pochybnost a nutí to aspoň zkusit (bohužel to teď nemohu najít, abych dal odkaz).ORDER BY language15 rows in set (11.39 sec), bez ORDER BY je to (0.39 sec) Potrebujem to však nutne vyriešiť, aby najprv radilo vysledky s language='sk' a až potom výsledky s language='en'. Rozmyšlam vytvoriť tab4 v podstate identickú s tab1 v počte riadkov so stĺpcami 'id' a 'sk', kde by bolo 'sk' buď 1, alebo 0, podľa toho či obsahuje language='sk' a potom dať ORDER BY tab4.sk, možno to bude radiť rýchlejšie.
language
? Potom byt mozno vedela databaza sekvencne citat zaznamy z toho indexu, namiesto citania vsetkych a nasledneho triedenia. To je totiz uzitocny side-effect indexu, ze udaje v jeho listoch su zoradene. Takze ak treba ORDER BY
, staci ist sekvencne podla indexu a testovat splnenie WHERE
; vsetko sa ale da urobit streamovo. A ked sa k tomu pridaju selektivne indexy z PostgreSQL alebo FBI z Oracle, staci dobry index a netreba overovat ani to WHERE
.
Tiskni
Sdílej: