Programovací jazyk JavaScript (Wikipedie) dnes slaví 30 let od svého oficiálního představení 4. prosince 1995.
Byly zveřejněny informace o kritické zranitelnosti CVE-2025-55182 s CVSS 10.0 v React Server Components. Zranitelnost je opravena v Reactu 19.0.1, 19.1.2 a 19.2.1.
Bylo rozhodnuto, že nejnovější Linux 6.18 je jádrem s prodlouženou upstream podporou (LTS). Ta je aktuálně plánována do prosince 2027. LTS jader je aktuálně šest: 5.10, 5.15, 6.1, 6.6, 6.12 a 6.18.
Byla vydána nová stabilní verze 3.23.0, tj. první z nové řady 3.23, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.
Byla vydána verze 6.0 webového aplikačního frameworku napsaného v Pythonu Django (Wikipedie). Přehled novinek v poznámkách k vydání.
Po více než 7 měsících vývoje od vydání verze 6.8 byla vydána nová verze 6.9 svobodného open source redakčního systému WordPress. Kódové jméno Gene bylo vybráno na počest amerického jazzového klavíristy Gene Harrise (Ray Brown Trio - Summertime).
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za listopad (YouTube).
Google Chrome 143 byl prohlášen za stabilní. Nejnovější stabilní verze 143.0.7499.40 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 13 bezpečnostních chyb.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,2 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,42 %. Procesor AMD používá 66,72 % hráčů na Linuxu.
Canonical oznámil (YouTube), že nově nabízí svou podporu Ubuntu Pro také pro instance Ubuntu na WSL (Windows Subsystem for Linux).
Zdravim,
potrebujem spravit taky selekct aby moje pozadovane ID bolo v strede. Priklad.
[id-2, id-1, id0, id1, id2]
kde ID0 je moje pozadovane. Da sa spravit taky selekt aby jednoducho zobral napr. 3 predchadzajuce 3 nasledujuce zaznamy?
Vdaka
no to je sice pekne, ale problem je ze tie ID nemusia ist za sebou. Co ak je tam [ 1, 5, 8, 10, 15, 50]. LIMITOM dakazem vytiahnut napr 3 zaznamy od 10 nahod, ale co tie nalavo?
Dobry den.
Potom muzete ten limit pouzit dvakrat + union.
Marek
WHERE id IN (SELECT id FROM tabulka WHERE id <= X LIMIT 3) OR id IN (SELECT id FROM tabulka WHERE id >= X LIMIT 3), což by bylo o něco hezčí.
Moje MySQL limit v poddotazu umí.
5.0.70. Jinak v dokumentaci píšou že limit se v subquery může normálně používat.
Malý omyl :) ano MySql 5 umí použít LIMIT clausuli v poddotazech, ale již ne ve spojením s IN :( - aspoň doufám, že se to nezměnilo :).
Lze:
SELECT * FROM t1
JOIN (SELECT id FROM t2 ORDER BY id LIMIT 0, 1000) AS t3
ON (t1.id = t3.id)
Ale NELZE:
SELECT * FROM t1 WHERE t1.id IN (SELECT id FROM t2 ORDER BY id LIMIT 0, 1000)
Je to tak. Dík za info.
Ale lze udělat kličku takto:
SELECT * FROM t1 WHERE t1.id IN (SELECT * FROM (SELECT id FROM t1 ORDER BY id LIMIT 0, 5) AS t2)
To bude fungovat prostě select s clausulí LIMIT se zapouzdří do selectu bez limitu,
ale pozor na výkonost při velkých tabulkách a hlavně velké hodnotě v LIMIT.
V Oracle (mozna i jinde) by slo pouzit analyticke funkce LAG a LEAD, ale snadno by to slo pouzit asi jen pro predem znamy rozsah okoli, napr. ty tri zaznamy na kazde strane. Obecne jak uz nekdo navrhoval unionem by to melo byt v pohode pro vetsinu tabulek, pro hodne velke bych to asi resil proceduralne (napr. PLSQL) na platformach kde je takova moznost. Primocare reseni pro predem znamy rozsah by slo pomoci not exists (prvni predchazejici je mensi nez master a neexistuje zadny mezi nimi atd.), coz muze na male tabulce rovnez fungovat, pokud tam bude vhodny index.
Takze spravim to zatial cez dva selekty:
SELECT * FROM tabulka WHERE id < X order by id desc LIMIT 3
SELECT * FROM tabulka WHERE id >= X LIMIT 4
A v PHP to spojim. Bohuzial moja verzia MySQL nepodporuje LIMIT v subquery.
Vdaka za pomoc.
Jano
Zkus radši toto i bez transakce: 15tka je hledane ID Je to takové transparentní a pokud se nejedná o součást nějakého velkého dotazu je to i rychlé (závorky jsou důležité!).
1. dotaz vezme před 3ks
2. dotaz vezme pozadovane ID
3. dotaze vezme po 3ks
(SELECT id FROM t1 WHERE id > 15 LIMIT 0, 3)
UNION
(SELECT id FROM t1 WHERE id = 15 LIMIT 0, 1)
UNION
(SELECT id FROM t1 WHERE id < 15 LIMIT 0, 3)
ORDER BY id
Neřeší to neexistenci 3 před a 3 po záznamů - nebylo to v dotazu specifikováno.
dosáhnou výsledku lze více způsoby, jen je třeba se vyhnou 'IN' v MySql.
Příklad přes PHP je třeba uzavřít do transakce. což není problém pokud se jedná o InnoDB tabulky, na MyIsam bohužel toto není možné.
Ale pokud se jedná například o web kde jeden zapisuje a mnoho lidí čte a není zklamání dotazu kritické, tak není problém i s takto optimistickým přístupem :).
Nicméně výkonostně je UNION výrazně rychlejší — jen 1x se komunikuje s MySql serverem.
Malá oprava
... doplněno řazení a přehozeni prvního a posledniho selectu aby to odpovídalo popisu výše:
(SELECT id FROM t1 WHERE id < 15 ORDER BY id DESC LIMIT 0, 3)
UNION
(SELECT id FROM t1 WHERE id = 15 LIMIT 0, 1)
UNION
(SELECT id FROM t1 WHERE id > 15 ORDER BY id ASC LIMIT 0, 3)
ORDER BY id
vdaka za rady :)
(SELECT id FROM t1 WHERE id <= 15 ORDER BY id DESC LIMIT 0, 4)
UNION
(SELECT id FROM t1 WHERE id > 15 ORDER BY id ASC LIMIT 0, 3)
ORDER BY id
Misto < tam jde dat <= a zredukovat to tak ze 3 poddotazu na 2. Pokud vim, ze ID existuje, tak bude vysledek stejny, jako u dotazu ze 3 casti. Pokud by ID neexistovalo, dostal bych 4 pred a 3 po.
Tiskni
Sdílej: