Jsongrep je open-source nástroj, který efektivně prohledává JSON dokumenty (editovat je neumí). Kompiluje regulérní jazyk dotazu do podoby deterministického konečného automatu (DFA), díky čemuž prochází strom JSON dokumentu pouze jednou a je v tom tedy rychlejší než jiné nástroje jako jsou například jq, JMESPath nebo jql. Jsongrep je napsaný v programovacím jazyce Rust, zdrojový kód je dostupný na GitHubu.
O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2026. Na programu je celá řada zajímavých přednášek a workshopů. Vstup na konferenci je zcela zdarma, bez nutnosti registrace. Přednášky lze sledovat i online na YouTube.
Mozilla a společnost Mila oznámily strategické partnerství za účelem rozvoje open source a suverénní AI. Cílem je ukázat, že open source AI může konkurovat uzavřeným systémům. Obě organizace chtějí posílit technologickou suverenitu a snížit závislost na hrstce velkých technologických firem.
Adam Rice předvedl, že pomocí DNS lze distribuovat a spustit kompletní hru DOOM. Rozdělil WAD soubory a binárky do téměř 2000 DNS záznamů v Cloudflare zóně (jeden TXT záznam v DNS může nést okolo 2000 znaků textu). Ty pak stáhl PowerShellem, dekomprimoval a spustil přímo v paměti počítače bez nutnosti zápisu na disk, což prakticky dokazuje, že DNS může sloužit jako distribuované úložiště dat a možný kanál pro načítání kódu. Repozitář projektu je na GitHubu.
Dnes a zítra probíhají Arduino Days 2026. Na programu je řada zajímavých přednášek. Sledovat je lze od 17:00 na YouTube. Zúčastnit se lze i lokálních akcí. Dnes v Poličce v městské knihovně a zítra v Praze na Matfyzu.
Byla vydána beta verze Ubuntu 26.04 LTS s kódovým názvem Resolute Raccoon. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 26.04 LTS mělo vyjít 23. dubna 2026.
Byla vydána aktualizována Příručka pro začínající wikipedisty a wikipedistky (pdf).
Ubuntu plánuje v budoucích verzích nahradit tradiční nástroje pro synchronizaci času (chrony, linuxptp a gpsd) novým, v Rustu napsaným ntpd-rs, který nabídne vyšší bezpečnost a stabilitu.
Byla vydána nová verze 7.6 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Správce hesel KeePassXC byl nahrazen správcem hesel GNOME Secrets. Bitcoinová peněženka Electrum byla povýšena na verzi 4.7.0. Tor Browser byl povýšen na verzi 15.0.8. Další novinky v příslušném seznamu.
Chris Down v obsáhlém článku „vyvrací mýty o zswap a zram“, vysvětluje, co vlastně dělají a jaké jsou mezi nimi rozdíly. Doporučuje vyhýbat se zram na serveru a bez OOM.
Dobrý den,
chtěl bych poprosit o radu, jak jednoduše transponovat tabulku v mysql. Sloupce na řádky a řádky na sloupce. Tabulka bude malinká. Těchto tabulek bude cca 20 a potřebuji to dát do jedné velké.
příklad tabulky
| rokmesic | chyby |
| 2008-01 | 0 |
| 2008-02 | 10 |
| 2008-03 | 5 |
| 2008-04 | 3 |
Předem děkuji
Zdraví Jura
Díval jsem se na ten crosstab, ale je to asi "klikací" záležitost (dev.mysql.com/doc/refman/5.0/en/connector-odbc-examples-tools-with-crystalreports.html). Nejde to udělat pomocí SQL ??
Děkuji
Jura
No moc nerozumím otázce. Přirovnal bych ji k otázce: "Jak pomocí vrtačky zatlouci hřebík ?".
Pokud potřebujete data nějak zformátovat (transponovat) tak to udělejte v zobrazovací vrstvě.
Pokud potřebujete tabulku, která poroste jak v počtu sloupců tak v počtu řádek tak udělejte datový model se dvěma dimenzemi:
Např: dimeze1 = rokmesic ; dimenze2 = typ_chyby ;
Tabulka CHYBY
| rokmesic | typ_chyby | pocet |
| 2008-01 | 1 | 0 |
| 2008-01 | 2 | 3 |
| 2008-02 | 1 | 10 |
| 2008-02 | 2 | 8 |
Tabulka TYP_CHYBY
| typ_chyby | popis |
| 1 | nevýznamná chyba |
| 2 | kritická chyba |
Zobrazení by se pak dělalo například takto (neodladěný pseudo kod)
print "<table> <tr><th> </th>"
sql1=connection.execute("select * from TYP_CHYBY order by typ_chyby")
while c=sql1.read do
print "<th>",c.popis,"</th>"
done
sql2=connection.execute("select * from CHYBY order by rokmesic, typ_chyby")
while c = sql2.read do
if c.typ_chyby=1 { print "<tr><td>",c.rokmesic,"</td>" }
print "<td>",c.pocet,"</td>"
if c.typ_chyby=2 { print "</tr>" }
done
print "</table>"
Zdravím,
děkuji za pomoc, ale nejedna se o chyby, jak asi myslite. SQL dotazem ziskam uvedenou tabulku a tu potrebuji transponovat.
Nejlepe pomoci SQL. Jde to ??
Jura
Ano jde to, s omezeními, ktará jsou daná přístupem v relačních DB. Je potřeba si uvědomit následující fakta:
Ve Vašem případě by "transpozice" mohla vypadat takto:
select *
from (select chyby as "2008-01" from CHYBY where rokmesic='2008-01') as S1
,(select chyby as "2008-02" from CHYBY where rokmesic='2008-02') as S2
,(select chyby as "2008-03" from CHYBY where rokmesic='2008-03') as S3
,(select chyby as "2008-04" from CHYBY where rokmesic='2008-04') as S4
Je to ošklivé řešení vyplývající z toho že výsledek SELECT nevrací matici, ale množinu záznamů nad kterou transpozice není definována.
Je to ošklivé řešení vyplývající z toho že výsledek SELECT nevrací matici, ale množinu záznamů nad kterou transpozice není definována.Přesně tak. Tudíž bych si v případě potřeby nahrál tabulku do matice v nějakém jiném jazyce (např. Perl) a transponoval tu.
Děkuji za pomoc. Počet řadku a sloupců bude mít tabulka fixní a slopec rokmesic bude zahlavi transponovane tabulky. Jde jen o prevedeni sloupce chyby na radek.
Ještě jednou moc děkuji
Jura
Tiskni
Sdílej: