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.
V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů
… více »SELECT f.* FROM jos_fi_firms AS f WHERE id IN( SELECT MAX(id) FROM jos_fi_firms AS f LEFT JOIN jos_fi_spec_firm AS sf ON f.id=sf.firm_id WHERE f.state=1 AND (LOWER(f.title) LIKE '%xx%' AND LOWER(f.region) LIKE '%%' OR LOWER(f.district) LIKE '%%' OR LOWER(f.city) LIKE '%%' OR LOWER(f.city_part) LIKE '%%') GROUP BY f.ico, f.title ) ORDER BY f.title
Tak se mi nikdy nedokončí, protože dříve vyprší doba běhu PHP skriptu, když dám ale každý z těchto dotazů samostatně, tak mi skončí skoro okamžítě.
EXPLAIN mi vypíše něco takového:
1 PRIMARY f ALL NULL NULL NULL NULL 16004 Using where; Using filesort 2 DEPENDENT SUBQUERY f ALL NULL NULL NULL NULL 16004 Using where; Using temporary; Using filesort 2 DEPENDENT SUBQUERY sf ref PRIMARY PRIMARY [BINARY - 1B] xxx.f.id 1 Using index
SELECT @uid:=IFNULL(u.id,0) AS id, IFNULL(u.name,0) AS name, @max_date:=(SELECT IFNULL(MAX(s.date),'0000-00-00') FROM jos_fi_stats AS s WHERE s.user_id=@uid) AS max_date, (SELECT COUNT(*) FROM jos_fi_firms AS f WHERE f.edited_by=@uid AND f.date>@max_date) AS cnt FROM jos_fi_firms AS f LEFT JOIN jos_users AS u ON f.edited_by=u.id GROUP BY f.edited_by
Na 16000 řádcích tabulky jos_fi_firms taky nikdy nedojede. Když spustím tento dotaz s EXPLAIN, tak mi to vypíše něco takového:
id select_type table type possible_keys key key_len ref rows Extra 1 PRIMARY f ALL NULL NULL NULL NULL 16004 Using temporary; Using filesort 1 PRIMARY u eq_ref PRIMARY PRIMARY [BINARY - 1B] xxx.f.edited_by 1 3 UNCACHEABLE SUBQUERY f ALL NULL NULL NULL NULL 16004 Using where 2 UNCACHEABLE SUBQUERY s system NULL NULL NULL NULL 0 const row not found
Nevíte někde, kde můžu mít chybu?Nebo jak ty dotazy zoptimalizovat? Doteď jsem si myslel, že nejlepší optimalizace je pomocí poddotazů, ale proč v prvním případě když použiju poddotazy, tak je dotaz nekonečný, zatímto když je spustím každý z těch dotazů samostatně, tak jsou hotové skoro okamžitě?
Předem děkuji za vaše rady
a co místo toho prvního dotazu zkusit:
SELECT * FROM ( SELECT f.* FROM jos_fi_firms AS f LEFT JOIN jos_fi_spec_firm AS sf ON f.id=sf.firm_id WHERE f.state=1 AND (LOWER(f.title) LIKE '%xx%' AND LOWER(f.region) LIKE '%%' OR LOWER(f.district) LIKE '%%' OR LOWER(f.city) LIKE '%%' OR LOWER(f.city_part) LIKE '%%') GROUP BY f.ico, f.title ORDER BY f.ID desc ) AS a ORDER BY f.titlemělo by to dělat to samé.
Tiskni
Sdílej: