Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).
Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.
V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.
Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.
Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.
Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).
Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.
Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Demence lidstva v kostce. Zvláštní věci mezi nebem a zemí se občas stávají. A to včetně situací mezi programátory, čili developery, jak se jim dnes říká. Vlastně má dnešní událost na svědomí nejspíše nějaký senior solution architect. Připravte si křupínky, zázvorové pivo a nechte se kolébat na vlnách stupidity.
Většina z vás, milé čtenářstvo, jistě zná The Daily WTF, kde zoufalí lidé od počítačů hledají uklidnění, a kde se baví na učet jiných. Dnes, respektive včera v noci jsem objevil podobnou věc.
Varování: podobnost kódu s tím, jaký jsi napsal právě ty, Karlíku (nebo Toníku), je čistě náhodná a v případě jakýchkoli problému vše zapřu, anebo budu tvrdit, že jsem si vše vymyslel. Klidně na počkání.
Jména objektů, proměnných jsem změnil, formátování a komentáře zanechal. A nyní – náš dramatický příběh začíná…
Za mlhou, která by se dala krájet, a ještě mnohem dále, než je rybníček Brčálník, leží království, nad nímž nekolik staletí slunce nezapadalo. Jedno z posledních království Evropské Unie. V něm jedna firma píše velice enterprise informační systémy za velice enterprice ceny.
Shodou pekelných okolností se mi do rukou dostal kód, který napsal jeden ze zaměstnanců oné společnosti, a který teď musí udržovat jeden kamarád, jak už to tak ve smutných příbězích bývá. Tento kód dokazuje, že i mezi Oracle databázovými specialisty jsou polodementní individua, jaká známe ze zapovězených a temných oblastí tečka síť a káva.
desc a_very_huge_one; Name Null Type --------- -------- ------------ TRANID NOT NULL NUMBER DTIME DATE VAL01 VARCHAR2(30) VAL02 VARCHAR2(30) VAL03 VARCHAR2(30) VAL04 VARCHAR2(30) VAL05 VARCHAR2(30) ... vypuštěno dalších 62 sloupců. Hádejte jak s jmenují. 69 rows selected
Ponechme stranou zprasené pojmenování sloupců, to dnes není důležité, perla teprve přichází ve fragmentu PACKAGE:
...
-- type for table A_VERY_HUGE_ONE row
TABTYPE IS RECORD(
TRANID NUMBER,
DTIME DATE,
VAL01 VARCHAR2(30),
VAL02 VARCHAR2(30),
VAL03 VARCHAR2(30),
VAL04 VARCHAR2(30),
... opět vyhozené nějaké řádky ...
VAL67 VARCHAR2(30));
...
FUNCTION A_VERY_STRANGE_ONE(DATEFROM DATE) RETURN VARCHAR2 AS
TABROW TABTYPE;
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
-- perform select from table
SELECT *
INTO TABROW
FROM A_VERY_HUGE_ONE
WHERE DTIME=DATEFROM AND
ROWNUM=1
ORDER BY TRANID DESC;
-- return val02 value
RETURN TABROW.VAL02;
-- rollback the transaction
ROLLBACK;
EXCEPTION
WHEN OTHERS THEN
-- return an empty string
ROLLBACK;
RETURN '';
END;
...
I teď, přestože na tanto hnůj koukám na šestistý pokus, nevím, jestli mám plakat, smát se anebo blít, drahý Ivánku. Také nevím, co je v té arcimrdce nejsmutnější. Jestli to, že původní autor zřejmě znal pár věcí, uměl třeba nadefinovat RECORD a uměl napsat pragmu, ale zřejmě vůbec netušil, co to dělá. Nebo jestli to, že je ten selekt naprosto na hovno, protože zjevně nedělá to, co má. Nebo jestli ty pochybné ROLLBACKY. Anebo ignorace ROWTYPE – třeba byl placen za počet znaků které napsal. Nebo jak krásně okomentoval kód, což zřejmě kdesi zaslechl, že se to má dělat… Nemluvme o tom, že ta tabulka má asi 600MB a na sloupci DTIME není index, ani žádne partyšny – na druhou strani je pak výstup z explainu velmi prostý a přečte jej i retardované vemeno. Neříkám ale, že pochopí.
Kontrolní otázka za 2 body: co se asi stane, když se daná tabulka musí rozšířit o jeden sloupec? Aneb ukázka kouzla "select * into" v celé své hrdé kráse.
Odhoďme filozofické otázky "proč tu jsme? Jaký je účel našeho života?" Jsou zbytečné. Účelem života takových lidí je pouze zbůhdarma promrhat kyslík ostatním a sežrat tuny pizzy, kterou si musí nechat vozit do openspace, kde sedí do devíti večer, protože si hodiny ošoupávají prsty psaním RECORDů. Vý-teč-ně, už se mi znovu vaří krev a oči se podlévají krví. Vraždil bych. K smrti rád.
Tiskni
Sdílej:
No ta sranda s ROWNUM a ORDER BY ... existuje někdo kdo se na tomhle aspoň jendou nespálil?
Ale to jde použít samozřejmě jen když má ROWNUM sloužit k omezení počtu řádků výsledku...
ale neptejte se proč, to si teda vážně nepamatuju).
(Zdá se mi to, nebo jsou oraclisti podobně nepříjemná sekta, jako javisti?
)