Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.
Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.
Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co
… více »Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).
Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.
Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno
… více »Konference Prague PostgreSQL Developer Day 2026 (P2D2) se koná 27. a 28. ledna 2026. Konference je zaměřena na témata zajímavá pro uživatele a vývojáře. Příjem přednášek a workshopů je otevřen do 14. listopadu. Vítáme témata související s PostgreSQL či s databázemi obecně, a mohou být v češtině či angličtině.
Byl vydán Devuan 6 Excalibur. Přehled novinek v poznámkách k vydání. Kódové jméno Excalibur bylo vybráno podle planetky 9499 Excalibur. Devuan (Wikipedie) je fork Debianu bez systemd. Devuan 6 Excalibur vychází z Debianu 13 Trixie. Devuan 7 ponese kódové jméno Freia.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu poprvé překročil 3 %, aktuálně 3,05 %. 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 27,18 %. Procesor AMD používá 67,10 % hráčů na Linuxu.
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: