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:55 | Nová verze

    Jonathan Thomas oznámil vydání nové verze 3.5.0 video editoru OpenShot (Wikipedie). Zdrojové kódy OpenShotu jsou k dispozici na GitHubu. Ke stažení je i balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit.

    Ladislav Hagara | Komentářů: 1
    dnes 00:55 | Nová verze

    Byla vydána (𝕏, Bluesky) nová verze 2026.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem 8 nových nástrojů v oficiálním oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 16:33 | IT novinky

    Vláda jmenovala novým zmocněncem pro digitalizaci a strategickou bezpečnost prvního náměstka ministra vnitra Lukáše Klučku. Ten ve funkci nahradil poslance Roberta Králíčka poté, co Králíček na tento post vládního zmocněnce rezignoval. Klučka chce do roka digitalizovat všechny státní služby tak, aby vyhověly zákonu o právu na digitální služby, přičemž dosavadní plán Fialovy vlády počítal s dokončením digitalizace až někdy v roce

    … více »
    NUKE GAZA! 🎆 | Komentářů: 10
    včera 13:55 | Nová verze

    Byl vydán Mozilla Firefox 149.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Vypíchnout lze bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně, zobrazení dvou webových stránek vedle sebe v jednom panelu (split view) nebo možnost přidat poznámky k panelům (Firefox Labs). Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 149 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 4
    včera 13:22 | Nová verze

    Byly vydány nové verze 5.3.0 a 6.0.0 svobodného multiplatformního programu pro skicování, malování a úpravu obrázků Krita (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Obě verze vycházejí ze stejného zdrojového kódu – rozdíl je v použitých verzích Qt a KDE Frameworks. Krita 6.0.0 je první vydání postavené na Qt 6 a stále je považovaná za experimentální. Má lepší podporu Waylandu. Přináší podporu protokolu Wayland

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 04:22 | Nová verze

    Byla vydána nová verze 10.2 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze nové balíčky Immich, Immich Machine Learning, uv a RustDesk Client.

    Ladislav Hagara | Komentářů: 0
    23.3. 22:11 | Nová verze

    TypeScript (Wikipedie), tj. JavaScript rozšířený o statické typování a další atributy, byl vydán v nové verzi 6.0. Příští verze 7.0 je kvůli výkonu přepisována do programovacího jazyka Go.

    Ladislav Hagara | Komentářů: 0
    23.3. 20:33 | Zajímavý článek

    Christian Schaller z Red Hatu na svém blogu popsal své zkušenosti s používáním AI při vývoji open source aplikací pro Linux. Pomocí různých AI aktualizoval nebo vytvořil aplikace Elgato Light GNOME Shell extension, Dell Ultrasharp Webcam 4K, Red Hat Planet, WMDock, XMMS resuscitated (aktualizace z GTK 2 a Esound na GTK 4, GStreamer a PipeWire) a Monkey Bubble. SANE ovladač pro skener Plustek OpticFilm 8200i se mu zatím nepovedl.

    Ladislav Hagara | Komentářů: 6
    23.3. 19:44 | IT novinky

    Americké firmy Tesla a SpaceX postaví v texaském Austinu moderní komplex na výrobu čipů pro umělou inteligenci (AI). Součástí projektu s názvem Terafab budou dvě moderní továrny na výrobu čipů – jedna se zaměří na automobily a humanoidní roboty, druhá na datová centra ve vesmíru. Uvedl to generální ředitel těchto firem Elon Musk. Projekt by podle odhadů měl stát 20 miliard USD (zhruba 425 miliard Kč).

    Ladislav Hagara | Komentářů: 17
    23.3. 15:00 | Nová verze

    Byla vydána nová stabilní verze 6.11 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1146 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    26.5.2014 11:39 Bhua
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Pri bug reportu nestaci poslat ukazku kodu na reprodukci v Perlu, ale musi se to prepsat do C? Co to je za srandovni firmu.
    26.5.2014 11:51 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    ... The DBD Oracle perl module is not supported by us.

    Regards,
    Habeeb.
    26.5.2014 11:54 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Popravde na zacatku nebylo uplne jasne, jestli je chyba v Oracle Instant Client nebo DBD::Oracle.
    Ted uz vim, ze je zabugovany i opatchovany tlusty klient.
    xvasek avatar 26.5.2014 12:07 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Můžeš být rád, že to nemusíš psát v Javě. :-)
    26.5.2014 12:13 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Javu ja rad.
    26.5.2014 12:16 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Oracle by teda mel byt s javou dost kamarad, ale pobavil me javaload.
    K anotacim v java zdrojacich se chova, jako by to mely byt SQL include, takze vyblije mraky file does not exist a vrati chybovy kod. Super pro make v automatickych testech.
    ;)
    26.5.2014 12:29 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    NULL je zlo a tabulka bez primarniho klice je intergalakticke zlo.
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    26.5.2014 12:40 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    To je extrahovane a osekane pro testcase.
    Tabulka, co nam to hazela v produkci, primarni klic samozrejme ma.
    27.5.2014 11:04 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Jakou verzi serveru/klienta máš?

    Já to zkouším s nepatchovaným serverem 12.1.0.1.0, instant client 11.2.0.3.0, všechno linux 64bit.

    A s qore driverem to jede:
    
    %new-style
    Datasource ds("oracle:omquser/omquser@xbox");
    any res = ds.selectRows("SELECT * FROM t_parents");
    printf("%N\n", res);
    
    list: (3 elements)
      [0]=hash: (1 member)
        parent : hash: (1 member)
          ID : 1
      [1]=hash: (1 member)
        parent : NULL
      [2]=hash: (1 member)
        parent : hash: (1 member)
          ID : 2
    
    Tím nechci hájit Oracle, podobných interních chyb jsem už viděl desítky. Ale většinou to bylo chybně použitým OCI.
    Kuolema Kaikille (Paitsi Meille).
    27.5.2014 11:18 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Konecne expert.
    Moje C je uz drobet rezave, tak jsem jel prevazne copy&paste z examples:
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <oci.h>
    
    struct parent_type {
      OCINumber id;
    };
    typedef struct parent_type parent_type;
    
    struct null_parent_type {
      OCIInd null_parent_type;
      OCIInd null_id;
    };
    typedef struct null_parent_type null_parent_type;
    
    static text *username = (text *) "username";
    static text *password = (text *) "password";
    static text *sid = (text *) "sid";
    
    static text *selall = (text *) "SELECT PARENT FROM t_parents";
    
    OCIDefine *defnp = (OCIDefine *) NULL;
    OCIType * parent_type_tdo;
    
    static parent_type *parentp[3];
    static null_parent_type *null_parentp[3];
    
    static OCIEnv *envhp;
    static OCIError *errhp;
    
    static void checkerr(/*_ OCIError *errhp, sword status _*/);
    static void cleanup(/*_ void _*/);
    static void myfflush(/*_ void _*/);
    int main(/*_ int argc, char *argv[] _*/);
    
    static sword status;
    
    int main(argc, argv)
    int argc;
    char *argv[];
    {
      sword errcode = 0;
      OCISession *authp = (OCISession *) 0;
      OCIServer *srvhp;
      OCISvcCtx *svchp;
      OCIStmt *stmthp;
    
      errcode = OCIEnvCreate((OCIEnv **) &envhp, (ub4) OCI_DEFAULT | OCI_OBJECT,
                      (dvoid *) 0, (dvoid * (*)(dvoid *,size_t)) 0,
                      (dvoid * (*)(dvoid *, dvoid *, size_t)) 0,
                      (void (*)(dvoid *, dvoid *)) 0, (size_t) 0, (dvoid **) 0);
    
      if (errcode != 0) {
        (void) printf("OCIEnvCreate failed with errcode = %d.\n", errcode);
        exit(1);
      }
    
      (void) OCIHandleAlloc( (dvoid *) envhp, (dvoid **) &errhp, OCI_HTYPE_ERROR,
                       (size_t) 0, (dvoid **) 0);
    
      /* server contexts */
      (void) OCIHandleAlloc( (dvoid *) envhp, (dvoid **) &srvhp, OCI_HTYPE_SERVER,
                       (size_t) 0, (dvoid **) 0);
    
      (void) OCIHandleAlloc( (dvoid *) envhp, (dvoid **) &svchp, OCI_HTYPE_SVCCTX,
                       (size_t) 0, (dvoid **) 0);
    
      (void) OCIServerAttach( srvhp, errhp, (text *)sid, strlen(sid), 0);
    
      /* set attribute server context in the service context */
      (void) OCIAttrSet( (dvoid *) svchp, OCI_HTYPE_SVCCTX, (dvoid *)srvhp,
                         (ub4) 0, OCI_ATTR_SERVER, (OCIError *) errhp);
    
      (void) OCIHandleAlloc((dvoid *) envhp, (dvoid **)&authp,
                            (ub4) OCI_HTYPE_SESSION, (size_t) 0, (dvoid **) 0);
    
      (void) OCIAttrSet((dvoid *) authp, (ub4) OCI_HTYPE_SESSION,
                     (dvoid *) username, (ub4) strlen((char *)username),
                     (ub4) OCI_ATTR_USERNAME, errhp);
    
      (void) OCIAttrSet((dvoid *) authp, (ub4) OCI_HTYPE_SESSION,
                     (dvoid *) password, (ub4) strlen((char *)password),
                     (ub4) OCI_ATTR_PASSWORD, errhp);
    
      checkerr(errhp, OCISessionBegin ( svchp,  errhp, authp, OCI_CRED_RDBMS,
                              (ub4) OCI_DEFAULT));
    
      (void) OCIAttrSet((dvoid *) svchp, (ub4) OCI_HTYPE_SVCCTX,
                       (dvoid *) authp, (ub4) 0,
                       (ub4) OCI_ATTR_SESSION, errhp);
    
      checkerr(errhp, OCIHandleAlloc( (dvoid *) envhp, (dvoid **) &stmthp,
               OCI_HTYPE_STMT, (size_t) 0, (dvoid **) 0));
    
      checkerr(errhp, OCIStmtPrepare(stmthp, errhp, selall,
                       (ub4) strlen((char *) selall),
                       (ub4) OCI_NTV_SYNTAX, (ub4) OCI_DEFAULT));
    
      checkerr(errhp, OCIDefineByPos(stmthp, &defnp, errhp, (ub4) 1, (dvoid *) 0,
                       (sb4) 0, SQLT_NTY, (dvoid *) 0, (ub2 *)0,
                       (ub2 *)0, (ub4) OCI_DEFAULT));
    
      checkerr(errhp, OCITypeByName(envhp, errhp, svchp, (const text *) 0,
                       (ub4) 0, (const text *) "PARENT_TYPE",
                       (ub4) strlen((const char *) "PARENT_TYPE"),
                       (CONST text *) 0, (ub4) 0,
                                    OCI_DURATION_SESSION,  OCI_TYPEGET_ALL,
                       &parent_type_tdo)); 
    
      checkerr(errhp, OCIDefineObject(defnp, errhp,
                       (OCIType *) parent_type_tdo,
                       (dvoid **)&parentp, (ub4 *) 0,
                       (dvoid **)&null_parentp, (ub4 *) 0));
    
      /* execute and fetch */
      if (status = OCIStmtExecute(svchp, stmthp, errhp, (ub4) 1, (ub4) 0,
                   (CONST OCISnapshot *) NULL, (OCISnapshot *) NULL, OCI_DEFAULT))
      {
        if (status == OCI_NO_DATA)
        {
        }
        else
        {
          checkerr(errhp, status);
          cleanup();
          return OCI_ERROR;
        }
      }
    
      while ((status = OCIStmtFetch(stmthp, errhp, (ub4) 1,  (ub4) OCI_FETCH_NEXT,
                          (ub4) OCI_DEFAULT)) == 0) {
      }
    
    }
    
    
    void checkerr(errhp, status)
    OCIError *errhp;
    sword status;
    {
      text errbuf[512];
      sb4 errcode = 0;
    
      switch (status)
      {
      case OCI_SUCCESS:
        break;
      case OCI_SUCCESS_WITH_INFO:
        (void) printf("Error - OCI_SUCCESS_WITH_INFO\n");
        break;
      case OCI_NEED_DATA:
        (void) printf("Error - OCI_NEED_DATA\n");
        break;
      case OCI_NO_DATA:
        (void) printf("Error - OCI_NODATA\n");
        break;
      case OCI_ERROR:
        (void) OCIErrorGet((dvoid *)errhp, (ub4) 1, (text *) NULL, &errcode,
                            errbuf, (ub4) sizeof(errbuf), OCI_HTYPE_ERROR);
        (void) printf("Error - %.*s\n", 512, errbuf);
        break;
      case OCI_INVALID_HANDLE:
        (void) printf("Error - OCI_INVALID_HANDLE\n");
        break;
      case OCI_STILL_EXECUTING:
        (void) printf("Error - OCI_STILL_EXECUTE\n");
        break;
      case OCI_CONTINUE:
        (void) printf("Error - OCI_CONTINUE\n");
        break;
      default:
        break;
      }
    }
    
    /*
     *  Exit program with an exit code.
     */
    void cleanup()
    {
      if (envhp)
        (void) OCIHandleFree((dvoid *) envhp, OCI_HTYPE_ENV);
      return;
    }
    
    
    void myfflush()
    {
      eb1 buf[50];
    
      fgets((char *) buf, 50, stdin);
    }
    
    
    
    Plus obligatni gcc pro InstantClient:
    gcc -I${ORACLE_HOME}/sdk/include -L${ORACLE_HOME} -lclntsh -o oci_replicate oci_replicate.c
    Pripadne full klient:
    gcc -I${ORACLE_HOME}/rdbms/public -L${ORACLE_HOME}/lib -lclntsh -o oci_replicate oci_replicate.c

    Podle mych testu zalezi na poradi radku v tabulce. Typ_A, NULL, Typ_B padne na hubu, ostatni jsou v poradku.
    Vazne by me zajimalo, jestli jsem udelal uplne stejnou chybu jako autori DBD::Oracle.
    xkucf03 avatar 28.5.2014 23:12 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Oracle daily WTF

    uff a to jim nestačí něco v Javě? Použít existujícího klienta a jen napsat SQL? JDBC ovladače snad podporují ne? (i když co si pamatuji, kdysi jsme s nimi bojovali a jejich „podpora“ byla dost na nic a to jsme byli celkem dost platící zákazník…)

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    29.5.2014 09:48 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    však to původně měl v "existujícím klientovi" (perl), ale O. support ho s tím poslal do hajzlu. Oni jsou ti indové dost svérázní.
    Kuolema Kaikille (Paitsi Meille).
    xkucf03 avatar 29.5.2014 14:43 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Nevím, kdo dělá perlovské ovladače, ale JDBC ovladač je přímo od Oraclu a za ten by měli ručit.
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    29.5.2014 14:52 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    V JDBC ovladaci budu tezko replikovat chybu C klienta kdezto perlovy DBD::Oracle je proti nemu linkovany.
    xkucf03 avatar 29.5.2014 16:02 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Jsou i JDBC-OCI ovladače.
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    29.5.2014 09:47 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    tak jsem se konečně dokopal k testu a zklamu tě. Normálně mi ten tvůj přiklad jede.
    Kuolema Kaikille (Paitsi Meille).
    29.5.2014 11:32 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    A jakeho klienta a db jsi teda otestoval? Je mozne, ze to na 12.1 databazi funguje..
    Ono je to celkem jedno. Az mi znovu otevre SR, tak uz ho nejak dotlacim k replikaci v jejich prostredi.
    V tuhle chvili tam mam "development working" na jednom ORA-600 a jednom ORA-7445. Vim, ze to neni prdel, ale jde to..
    ;)
    29.5.2014 14:04 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    stejně jako předtím: servere 12.1.0.1.0, instant client 11.2.0.3.0
    Kuolema Kaikille (Paitsi Meille).
    25.6.2014 12:23 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    No uz se nemusime hadat.
    Viz Bug 18937413 : OCI-21500: INTERNAL ERROR CODE, ARGUMENTS: [KODRSOBJ1].
    25.6.2014 16:27 s0 | skóre: 32 | blog: nejchytřejší kecy | prágl
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Tak moc jsme se nehádali, já si jen oveřoval, že to "U mne funguje (tm)" Tohleto Oracle je dost prevít. Každopádně opravu očekávám někdy kolem roku 2023...
    Kuolema Kaikille (Paitsi Meille).
    27.5.2014 11:24 alkoholik | skóre: 40 | blog: Alkoholik
    Rozbalit Rozbalit vše Re: Oracle daily WTF
    Jo, jeste odpoved na otazku: Instant Client 11.1, 11.2, 12.1, full klient 11.2 proti db 11.1 a 11.2.
    Nebyla to kombinace vseho proti vsemu, ale proste tam ta chyba je.
    BTW: SQLplus z IC ten select taky bez problemu vypise..

    Založit nové vláknoNahoru

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

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