Připojte se ve středu 30. 10. 2024 od 10:00 do 12:00 na náš webinář "Řízení přístupu do PostgreSQL prostřednictvím externího autentizačního providera" (registrace zdarma) a naučte se, jak nastavit ověřování pomocí GSSAPI pro bezpečný přístup k databázím (Microsoft Active Directory nebo FreeIPA). Záznam předchozího webináře "Co je nového v PostgreSQL 17" můžete zhlédnout zde.
… více »Byla vydána nová verze 0.55 open source počítačové hry Unvanquished (Wikipedie), forku počítačové hry Tremulous. Instalovat ji lze také z Flathubu.
Dle plánu bylo dnes vydáno Factorio 2.0 a Factorio: Space Age, tj. aktualizace 2.0 počítačové hry Factorio (Wikipedie) oficiálně běžící také na Linuxu a velké vesmírní rozšíření Factorio: Space Age.
Byl zveřejněn průběžně aktualizovaný program konference OpenAlt 2024 o otevřeném softwaru a datech, IT bezpečnosti, DIY a IoT. Konference proběhne o víkendu 2. a 3. listopadu v prostorách FIT VUT v Brně. Vstup je zdarma.
Ubuntu oslavilo 20 let. První Ubuntu 4.10 s kódovým názvem Warty Warthog bylo vydáno 20. října 2004.
Vizuální programovací jazyk MicroBlocks určený pro programování mikropočítačů jako micro:bit pomoci bloků byl vydán v nové verzi 2.0. MicroBlocks je inspirovaný Scratchem.
Mapy.cz zavádí placenou verzi Premium (𝕏). Cena předplatného bude zveřejněna v další verzi aplikace (𝕏). Aplikace i web budou dál fungovat zdarma. Mění se způsob ukládání offline map. Nově bude možné bezplatně uložit offline mapu pouze jednoho státu (𝕏).
Byla vydána nová verze 8.10 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Pravděpodobně poslední osmičková verze. V průběhu několika měsíců by měla vyjít verze 9.
O víkendu 19. a 20. října lze na brněnském výstavišti v pavilonu A1 navštívit s jednou vstupenkou dvě akce: Maker Faire Brno, "festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí", a GameDev Connect, "akci určenou pro všechny současné a hlavně budoucí herní vývojáře, kteří touží proniknout do jednoho z nejúžasnějších průmyslů na světě".
Asterisk (Wikipedie), svobodná softwarová implementace telefonní ústředny (PBX), byl vydán ve verzi 22.0.0. Přehled novinek v této nové major verzi v oznámení na webu a na GitHubu.
Zdravim.
Mam nasledujici problem. Mam ulozeny IP adresy v 5 tabulkach. Potreboval bych pomoci SQL dotazu vybrat vsechny IP adresy ze vsech tabulek, "zgrupovat" duplicitni zaznamy a zaroven spocitat, kolikrat se ktera IP adresa ve vsech tabulkach nachazela. Pro jednu tabulku jsem to resil naledovne - "SELECT IP, COUNT(*) as Pocet FROM tabulka GROUP BY IP", ale pro vice tabulek jsem bezradny.
dekuji za pomoc Petr
btw. "nalit" vsechny data do jedne tabulky se mi nechce, protoze v kazde tabulce je cca 0,5 mil zaznamu.
Diky, toto mi bohuzel nepomohlo - neslo o JOIN ale o UNION (kde je ale problem s funkci COUNT)
Vyresil jsem to tak, ze jsem vytvoril view do ktereho jsem vybral IP adresy ze vsech tabulek (pomoci UNION ALL) a nasledny COUNT a GROUP BY jsem udelal nad timto view.
Pokud by se nekomu podarilo nacpat vse do "jednoho" SQL dotazu, tak pro zajimovost prosim o zaslani. Alespon bych udelal benchmark co je rychlejsi
Neznám strukturu tabulek, ale napadá mě toto:
SELECT ip_address, COUNT(1) FROM (SELECT ip AS ip_address FROM ip1 UNION ALL SELECT ip FROM ip2) GROUP BY ip_address /
Pokud tě zajímají hlubší statistiky, například groupovat i po tabulkách (postupné součty), jde to udělat takto:
SELECT ip_address, table_type, COUNT(1) FROM (SELECT ip AS ip_address, 1 AS table_type FROM ip1 UNION ALL SELECT ip, 2 FROM ip2) GROUP BY ip_address, table_type /
Postupné součty:
SELECT table_type, ip_address, COUNT(1) FROM (SELECT ip AS ip_address, 1 AS table_type FROM ip1 UNION ALL SELECT ip, 2 FROM ip2) GROUP BY ROLLUP ( table_type, ip_address) /
Na databázích, které nepodporují GROUP BY ROLLUP
, se to musí trošku vochcat:
SELECT table_type, ip_address, COUNT(1) FROM (SELECT ip AS ip_address, 1 AS table_type FROM ip1 UNION ALL SELECT ip, 2 FROM ip2) GROUP BY table_type, ip_address UNION ALL SELECT table_type, NULL, COUNT(1) FROM (SELECT ip AS ip_address, 1 AS table_type FROM ip1 UNION ALL SELECT ip, 2 FROM ip2) GROUP BY table_type UNION ALL SELECT NULL, NULL, COUNT(1) FROM (SELECT ip AS ip_address, 1 AS table_type FROM ip1 UNION ALL SELECT ip, 2 FROM ip2) /
Z toho je vidět, že se musí ty tabulky probrousit několikrát, což není dvakrát cool. Ale naštěstí Oracle i DB2 je v klidu.
Co se výkonu týče, byl bych úplně vklidu. Zrovna dneska jsem třeba dopsal SELECT
, který brousí tabulky s několika miliony záznamů. Je to celkem zajímavý report, tak mě to bavilo. A výsledková sada je u klienta do 30 sekund. Ani jsem neřešil indexy protože by to stejně při tak malém množství vyšlo na FULL SCAN.
Dobrá, tak vážně. Pokud s datovou strukturou nemůžeš pohnout, zajímal bych se o materializované pohledy. Jak jsem to pochopil, spíš se u tebe jedná o nějaké logy, takže spíš pod tlakem smažíš nové záznamy. Materializovaný pohled umí být FAST REFRESH ON COMMIT
, což by mělo jít na MySQL nějak očurat (ano, fackuju se) triggerem. Kdyžtak kdykoli můžeš ty logy odlejt někam do historie, udělat z nich agregát a k němu pak připočítávat (tabulka IP_AVG
obsahuje ten agregát tabulky IP1) (sakra, já jsem dneska nějakej dobrej; asi bych toho měl už nechat…):
SELECT NVL(x.ip, y.ip) AS ip, NVL(x.cnt, 0) + NVL(y.cnt, 0) AS cnt FROM (SELECT ip, COUNT(1) AS cnt FROM ip2 GROUP BY ip) x FULL OUTER JOIN (SELECT ip, cnt FROM ip_avg) y ON (x.ip = y.ip) /
Až na ten FULL OUTER JOIN
se mi to líbí. A ten jde obejít takto:
SELECT ip, SUM(cnt) FROM (SELECT ip, COUNT(1) AS cnt FROM ip2 GROUP BY ip UNION ALL SELECT ip, cnt FROM ip_avg) GROUP BY ip /
Jo. A místo NVL()
jde použít NULLIF()
.
A mimochodem: díky za zpříjemnění večera. Už jsem se bál, že se budu nudit.
P.S.: Jako obvykle: v příloze je skript na hraní; tak hodně štěstí!
Tiskni Sdílej: