Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.
Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.
Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.
Byla vydána nová verze 1.54.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Jan Václav.
Knižní edice správce české národní domény přináší novou knihu zkušeného programátora Pavla Tišnovského s názvem Programovací jazyk Go. Publikace nabízí srozumitelný a prakticky zaměřený pohled na programování v tomto moderním jazyce. Nejedná se však o klasickou učebnici, ale spíše o průvodce pro vývojáře, kteří s Go začínají, nebo pro ty, kdo hledají odpovědi na konkrétní otázky či inspiraci k dalšímu objevování. Tištěná i digitální verze knihy je již nyní k dispozici u většiny knihkupců.
OpenAI zpřístupnila (en) nové nenáročné otevřené jazykové modely gpt-oss (gpt-oss-120b a gpt-oss-20b). Přístupné jsou pod licencí Apache 2.0.
Byla vydána RC verze openSUSE Leap 16. S novým instalátorem Agama, Xfce nad Waylandem a SELinuxem.
Google Chrome 139 byl prohlášen za stabilní. Nejnovější stabilní verze 139.0.7258.66 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře. S verzí 139 přestal být podporován Android 8.0 (Oreo) a Android 9.0 (Pie).
update tb1
set cosi = neco_jinyho
from
(
select
tb1.id,
agregacni_fce(kousicky) neco jinyho
from tI join tII
on tb1.id = tII.id
group by tb1.id
)dta
where tb1.id = dta.id
(snad sem nic nevynechal)for i in 1..(select count(*)/500 from tbl) loop
update tbl1
........ where ctid between i*500 and (i+1) * 500;
end loop;
bude tohle delat to co potrebuju
Zkus tohle:update tb1 set cosi = neco_jinyho from ( select tb1.id, agregacni_fce(kousicky) neco jinyho from tI join tII on tb1.id = tII.id group by tb1.id )dta where tb1.id = dta.id
UPDATE tb1 SET tb1.cosi = (SELECT AGG(...) AS neco_jinyho FROM tii INNER JOIN ti ON (tii.id = ti.ref_id) -- uprav si Join Condition WHERE tii.id = tb1.id GROUP BY tii.id) WHERE EXISTS (SELECT 1 FROM tii INNER JOIN ti ON (tii.id = ti.ref_id) -- viz výše WHERE tii.id = tb1.id) /Tohle prostě musí fungovat. Takovýhle dotazy pouštím obden nad miliony záznamy. Ta
GROUP BY
klauzule tam vpodstatě být nemusí, protože v SELECT
klauzuli je jen ta agregačka.
Dotaz zupdatuje sloupek COSI
výpočtem nějaký agregačky pro všechny záznamy tabulky TB1
, pro které existují odpovídající záznamy ve spojení tabulek TI
a TII
.
Rozdělení na více dotazů moc nedoporučuji. Dělá to jen problémy.
Podle toho, co jsem z tvého příkladu pochopil, omezuješ množinu TII
množinou TI
. Jinými slovy, v tabulce TII
máš víc záznamů, které nechceš zahrnout do agregačky. V tom případě doporučuji udělat dočasnou tabulku:CREATE TABLE tmp_data AS SELECT tii.id AS tii_id, "další", "sloupce", "pro", "agregačku" FROM tii INNER JOIN ti ON (tii.id = ti.ref_id) -- uprav si Join Condition / CREATE INDEX idx_tmpdata ON tmp_data (tii_id) /a vypočítat tuto agregačku z této tabule. V případě, že tabulka
TII
obsahuje více nerelevantních záznamů než tabulka TB1
, můžeš tyto záznamy též odstranit například dalším INNER JOIN
em. Ten index může být klidně složený. Databázi pak bude stačit probrousit index a s přístupem do vlastní tabule nebude ztrácet čas.
Když i tohle bude málo, pak si z týhle tabule předpočítej i tu agregačku a to už musí fungovat i kdybys nechtěl.
update hrany
set geometrie = geom from
(select id_hrany, aggrfce(geom_body)
from spojeni, body
where
spojeni.id_hrany = body.id_hrany
order by id_hrany, id_bodu
group by id_hrany
)hrgm
on id_hrany = id_hrany
update hranice_parcel
set geometry = geom.geometry
from
(
select
hp_id,
ST_MakeLine(geometry) geometry
from
(
select
hp_id, sour.geometry
from
spojeni_b_poloh spojeni,
souradnice_obrazu sour
where
sour.id = spojeni.bp_id
order by poradove_cislo_bodu
offset 0
) body
where hp_id is not null
group by hp_id
having count(*)>1 --pridano
offset 0
) geom
where hp_id = hranice_parcel.id;
"Update (cost=730850.00..732569.06 rows=200 width=173)"
" -> Nested Loop (cost=730850.00..732569.06 rows=200 width=173)"
" -> Subquery Scan on geom (cost=730850.00..730855.50 rows=200 width=87)"
" -> Limit (cost=730850.00..730853.50 rows=200 width=55)"
" -> HashAggregate (cost=730850.00..730853.50 rows=200 width=55)"
" Filter: (count(*) > 1)"
" -> Subquery Scan on body (cost=685441.55..713875.14 rows=2263314 width=55)"
" Filter: (body.hp_id IS NOT NULL)"
" -> Limit (cost=685441.55..691128.27 rows=2274687 width=49)"
" -> Sort (cost=685441.55..691128.27 rows=2274687 width=49)"
" Sort Key: spojeni.poradove_cislo_bodu"
" -> Hash Join (cost=56887.43..212019.03 rows=2274687 width=49)"
" Hash Cond: (spojeni.bp_id = sour.id)"
" -> Seq Scan on spojeni_b_poloh spojeni (cost=0.00..72125.87 rows=2274687 width=28)"
" -> Hash (cost=41356.30..41356.30 rows=729530 width=43)"
" -> Seq Scan on souradnice_obrazu sour (cost=0.00..41356.30 rows=729530 width=43)"
" -> Index Scan using ih_hp_id on hranice_parcel (cost=0.00..8.56 rows=1 width=109)"
" Index Cond: (hranice_parcel.id = geom.hp_id)"
ERROR: out of memory DETAIL: Failed on request of size 27. ********** Chyba ********** ERROR: out of memory Stav SQL: 53200 Podrobnosti:Failed on request of size 27.
update tI set cosi = neco_jinyho from tI join ( select id, agregacni_fce(kousicky) neco_jinyho from tI join tII on tI.id = tII.id group by tI.id )dta on tI.id = dta.idcož by ve výsledku nemuselo bejt tak paměťově náročný
Tiskni
Sdílej: