abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 01:11 | Pozvánky

    Konečně se ochladilo, možná i díky tomu přestaly na chvíli padat rakety jako přezrálé hrušky, díky čemuž se na Virtuální Bastlírně dostane i na jiná, přízemnější témata. Pokud si chcete jako každý měsíc popovídat s dalšími bastlíři, techniky, vědci a profesory u virtuálního pokecu u piva, Virtuální Bastlírna je tu pro Vás.

    Ještě před ochlazením se drát na vedení V411 roztáhl o 17 metrů (přesné číslo není známé, ale drát nepřežil) a způsobil tak… více »
    bkralik | Komentářů: 0
    včera 23:44 | Komunita

    Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.

    Ladislav Hagara | Komentářů: 0
    1.8. 15:44 | Nová verze

    PixiEditor byl vydán ve verzi 2.0. Jedná se o multiplatformní univerzální all-in-one 2D grafický editor. Zvládne rastrovou i vektorovou grafiku, pixel art, k tomu animace a efekty pomocí uzlového grafu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GNU LGPL 3.0.

    Ladislav Hagara | Komentářů: 1
    1.8. 13:22 | Nová verze

    Byly představeny novinky v Raspberry Pi Connect for Organisations. Vylepšen byl protokol auditu pro lepší zabezpečení. Raspberry Pi Connect je oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče. Verze pro organizace je placená. Cena je 0,50 dolaru za zařízení za měsíc.

    Ladislav Hagara | Komentářů: 0
    1.8. 01:33 | Zajímavý software

    CISA (Cybersecurity and Infrastructure Security Agency) oznámila veřejnou dostupnost škálovatelné a distribuované platformy Thorium pro automatizovanou analýzu malwaru. Zdrojové kódy jsou k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 0
    31.7. 17:22 | Nová verze Ladislav Hagara | Komentářů: 0
    31.7. 16:11 | Zajímavý software

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia Proton Authenticator. S otevřeným zdrojovým kódem a k dispozici na všech zařízeních. Snadno a bezpečně synchronizujte a zálohujte své 2FA kódy. K používání nepotřebujete Proton Account.

    Ladislav Hagara | Komentářů: 0
    30.7. 16:22 | Zajímavý článek

    Argentinec, který byl náhodně zachycen Google Street View kamerou, jak se zcela nahý prochází po svém dvorku, vysoudil od internetového giganta odškodné. Soud uznal, že jeho soukromí bylo opravdu porušeno – Google mu má vyplatit v přepočtu asi 12 500 dolarů.

    Ladislav Hagara | Komentářů: 15
    30.7. 13:55 | IT novinky

    Eben Upton, CEO Raspberry Pi Holdings, informuje o RP2350 A4, RP2354 a nové hackerské výzvě. Nový mikrokontrolér RP2350 A4 řeší chyby, i bezpečnostní, předchozího RP2350 A2. RP2354 je varianta RP2350 s 2 MB paměti. Vyhlášena byla nová hackerská výzva. Vyhrát lze 20 000 dolarů.

    Ladislav Hagara | Komentářů: 0
    29.7. 14:44 | IT novinky

    Představen byl notebook TUXEDO InfinityBook Pro 15 Gen10 s procesorem AMD Ryzen AI 300, integrovanou grafikou AMD Radeon 800M, 15,3 palcovým displejem s rozlišením 2560x1600 pixelů. V konfiguraci si lze vybrat až 128 GB RAM. Koupit jej lze s nainstalovaným TUXEDO OS nebo Ubuntu 24.04 LTS.

    Ladislav Hagara | Komentářů: 18
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (29%)
     (28%)
     (5%)
     (7%)
     (4%)
     (1%)
     (2%)
     (24%)
    Celkem 198 hlasů
     Komentářů: 21, poslední 30.7. 22:56
    Rozcestník

    Milé malé WTF

    7.9.2006 11:04 | Přečteno: 1667× | sw | Výběrový blog

    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.

           

    Hodnocení: 87 %

            špatnédobré        

    Anketa

    Kontrolní otázka za 2 body: co se asi stane, když se daná tabulka musí rozšířit o jeden sloupec?
     (16 %)
     (58 %)
     (26 %)
    Celkem 80 hlasů

    Anketa

    Kontrolní otázka za 2 body: co se asi stane, když se daná tabulka musí rozšířit o jeden sloupec?
     (0 %)
     (0 %)
     (0 %)
    Celkem 0 hlasů

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    7.9.2006 11:37 zabza | skóre: 52 | blog: Nad_sklenkou_cerveneho
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Přidáš sloupeček a ... taková funkce co vrací NULL se vždycky hodi :-)

    No ta sranda s ROWNUM a ORDER BY ... existuje někdo kdo se na tomhle aspoň jendou nespálil?
    7.9.2006 11:44 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Milé malé WTF
    hehehe, podle mne neexistuje. Se slzou v oku vzpomínám, jak jsme se na tom nechali nachytat ve třech lidech. Přepisovali jsme pak asi šest baliků, a to velice rychle a se studem.
    Kuolema Kaikille (Paitsi Meille).
    7.9.2006 12:04 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Třeba já, používám Firebird… :-p ;-)
    wake avatar 8.9.2006 00:50 wake | skóre: 30 | blog: wake | Praha
    Rozbalit Rozbalit vše Re: Milé malé WTF
    treba ja, pouzivam manual.
    Tento příspěvek má hlavičku i patičku!
    xvasek avatar 7.9.2006 13:35 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Milé malé WTF
    V MSSQL ROWNUM radši ani není, musí se to složitě emulovat. (Nebo neumím hledat.)
    7.9.2006 13:45 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Milé malé WTF
    neni tam TOP? anebo si to nejak tak pamatuju z dob mssql6
    Kuolema Kaikille (Paitsi Meille).
    7.9.2006 13:47 zabza | skóre: 52 | blog: Nad_sklenkou_cerveneho
    Rozbalit Rozbalit vše Re: Milé malé WTF
    ... je, a překvapivě se vyhodnocuje až po ORDER BY :-) Ale to jde použít samozřejmě jen když má ROWNUM sloužit k omezení počtu řádků výsledku...
    7.9.2006 13:53 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Hmm, k čemu jinému by mělo sloužit? K pseudonáhodnému výběru záznamů, které se v dalším kroku úhledně seřadí? :-D
    7.9.2006 14:14 zabza | skóre: 52 | blog: Nad_sklenkou_cerveneho
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Vy jste nikdy nepoužil ROWNUM k něčemu jinému? To bych měl někde vyhrabat jedno view, co jsem kdysi spáchal, a bylo opravdu ošklivé (šlo o něco jako že jsem potřeboval join mezi sudýma řádkama v jedné tabulce s lichýma ve druhé ... :-) ale neptejte se proč, to si teda vážně nepamatuju).
    7.9.2006 18:55 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Zaprvé nejsem oraclista, zadruhé, jak může (bez explicitního řazení) relační databáze zaručit, které řádky budou liché a které sudé?
    7.9.2006 19:41 zabza | skóre: 52 | blog: Nad_sklenkou_cerveneho
    Rozbalit Rozbalit vše Re: Milé malé WTF
    samozřejmě, šlo o sudé a liché řádky v explicitním řazení
    xvasek avatar 7.9.2006 15:37 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Top je podle toho, co umí rownum, jenom dětské prdění do vody...
    wake avatar 8.9.2006 00:52 wake | skóre: 30 | blog: wake | Praha
    Rozbalit Rozbalit vše Re: Milé malé WTF
    select * from tabulka where rownum > 1;
    Tento příspěvek má hlavičku i patičku!
    9.9.2006 15:52 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Ano, to je opravdu konstrukce, bez které by se celý Oracle sesypal jako domeček z karet… :-D (Zdá se mi to, nebo jsou oraclisti podobně nepříjemná sekta, jako javisti? :-D)
    10.9.2006 12:42 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Milé malé WTF
    ne, ne, ne! Oraclisti jsou krásní, chytří a všeobecně oblíbení, zatímco Javisti jsou zlí, bijí koťátka a dupou po karafiátech.
    Kuolema Kaikille (Paitsi Meille).
    10.9.2006 14:37 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Ach, děkuji za vysvětlení, švarný junáku, tápal jsem dosud v temnotách… :-D
    clayman avatar 7.9.2006 12:39 clayman | skóre: 13 | Praha 6
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Bohuzel nejsem databazista a SQL neznam, takze vtip mi utekl. :-(
    Josef Kufner avatar 7.9.2006 18:35 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Milé malé WTF
    To nevadí, patlat prasečinky lze v čemkoliv. V poslední době mě dostal kus php, kde vytáh všecky řádky z db a za tím následoval foreach, kde to prasátko víceméně emulovalo WHERE a možná i JOIN ...
    Hello world ! Segmentation fault (core dumped)
    Daniel Kvasnička ml. avatar 7.9.2006 13:50 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: Milé malé WTF
    S db nepracuju tak casto, abych mel chut to cist do konce, ale za anketu jsem ti dal hodnoceni 3 ;-)
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    7.9.2006 21:39 xxxxxxxx | skóre: 16 | blog: mrtvy blog | v nebi
    Rozbalit Rozbalit vše Re: Milé malé WTF
    CHCEME VÍC NEJCHYTŘEJŠÍCH KECŮ!!!!! VÍC!!!! VÍC!!!!!!!
    wake avatar 8.9.2006 00:48 wake | skóre: 30 | blog: wake | Praha
    Rozbalit Rozbalit vše Re: Milé malé WTF
    to je jasny. job security. z tohohle _nikdo_ nepozna, co to vlastne ma delat. autor je nepostradatelny.
    Tento příspěvek má hlavičku i patičku!
    8.9.2006 11:10 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: Milé malé WTF
    No, takové obvyklé WTF. I když je pravda že jako ne-Oraclista nepoznám, co jsou normální Oracle triky a co je jen blbost autora.

    Co je ale opravdu WTF, je onen odkaz na stránky "no Java", které asi původné byly zamýšlany jako veselé historky o středu kravaťáků a hackerů. Ovšem výsledek je odporný a trapný, zvláště ten první ICQ rozhovor je velmi ubohý (chápal bych v hospodě po pátém pivu, chápu i vtipkování po ICQ, ale veřejně to vystavovat na webu?).
    21.1.2010 19:26 vaclav
    Rozbalit Rozbalit vše Re: Milé malé WTF
    Tahle prihoda mi pripomina jeden chemickej vtip: H4SO3 :D:D:D(chemici vedi).

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.