Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
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.
select * (
select * from tab1
join (select rec, max(datum) from tab2 where krok = "kroka") as s1
on tab1.rec = s2.rec
join (select rec, max(datum) from tab2 where krok = "krokb") as s2
on tab1.rec = s2.rec
)
where s1.datum > s2.datum
select t1.rec, max(krok_a.datum)
from t1, t2 krok_a
where t1.rec = krok_a.rec
and krok_a.krok = 'KrokA'
and not exists( select 0 from t2 krok_b
where krok_b.rec = t1.rec
and krok_b.krok = 'KrokB'
and krok_b.datum > krok_a.datum)
group by t1.rec
konkretne toto lze udelat jednoduchym group by jen nad tabulkou t2, coz doporucuju jako cviceni.
Asi tak nějak (čistě syntaktický přepis Vašeho zadání):
select t1.Rec
from TAB1 as t1
join TAB2 as t2
on t1.Rec=t2.Rec and t.Krok='KrokA' and t1.Typ=1
left join (
select Rec,min(Datum) as dt
from TAB2
where Krok='KrokB'
group by Rec
) as t3
on t2.Rec=t3.Rec and t2.Datum < t3.dt
where t3.Rec is null
Kdyby jste uvedl co je v TAB2 (primárním) klíčem, tak to možná šlo ještě jednodušeji ( jedna agregace plus jeden join ).
Zase jen syntaktický přepis (bez jakékoliv znalosti skutečného problému)
select
Rec
,max(case when Krok='KrokA' then Date else null end ) -- poslední datum pro KrokA
from TAB2
group by Rec
having
max( case when Krok='KrokA' then Date else null end ) -- nejvyssi datum pro KrokA ( = poslední)
> -- je větší než
max( case when Krok='KrokB' then Date else null end ) -- nejvyšší datum pro KrokB
Ještě jsem zapoměl na dva okrajové případy, kdy jeden z kroků není k dispozici
select
Rec
,max(case when Krok='KrokA' then Date else null end ) -- poslední datum pro KrokA
from TAB2
group by Rec
having
max( case when Krok='KrokA' then Date else null end ) is not null -- existuje krokA
and -- a zároveň
(
max( case when Krok='KrokA' then Date else null end ) -- nejvyssi datum pro KrokA ( = poslední)
> -- je větší než
max( case when Krok='KrokB' then Date else null end ) -- nejvyšší datum pro KrokB
or -- nebo se krokB nedohledá
max( case when Krok='KrokB' then Date else null end ) is NULL
)
Tiskni
Sdílej: