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 15:55 | Komunita

Free Software Foundation (FSF, Nadace pro svobodný software) publikovala nové video s názvem The University of Costumed Heroes. Jedná se o součást kampaně za používání svobodného softwaru při distanční výuce.

Ladislav Hagara | Komentářů: 2
včera 13:33 | Zajímavý projekt

Vývojáři přenosného počítače Pocket Popcorn Computer (Pocket P.C.) (zprávička) informují na svém blogu, že návrh hardwaru zveřejnili na GitHubu pod licencí CC BY-SA 3.0 US.

Ladislav Hagara | Komentářů: 3
včera 08:00 | Zajímavý článek

David Revoy, autor mj. komiksu Pepper&Carrot, zveřejnil novou iteraci své instalační příručky pro použití Kubuntu, nyní 20.04, jako grafické pracovní stanice.

Fluttershy, yay! | Komentářů: 3
včera 02:00 | IT novinky

Počátkem roku někdo odcizil z Intelu několik GB citlivých dat. Prvních 20 GB bylo zveřejněno [Hacker News, ZDNet].

Ladislav Hagara | Komentářů: 7
6.8. 19:33 | Nová verze

Bylo vydáno Ubuntu 20.04.1 LTS, tj. první opravné vydání Ubuntu 20.04 LTS s kódovým názvem Focal Fossa. Přehled novinek v poznámkách k vydání a v přehledu změn. Součástí oznámení je infografika Ubuntu od 2004 do 20.04 LTS (png).

Ladislav Hagara | Komentářů: 0
6.8. 18:00 | Pozvánky

MojeFedora.cz upozorňuje na letošní Flock aneb letošní online konferenci zaměřenou na přispěvatele do Fedory. Konference probíhá od zítra 7. srpna do neděle 9. srpna, viz program.

Ladislav Hagara | Komentářů: 0
6.8. 15:00 | Nová verze

Po půl roce od vydání verze 2.31 byla vydána verze 2.32 knihovny glibc (GNU C Library). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 1
6.8. 09:33 | IT novinky

Dnes končí bezpečnostní konference Black Hat USA 2020 (Twitter) a začíná bezpečnostní konference DEF CON 28 (Twitter). Kvůli onemocnění COVID-19 ne v Las Vegas, ale pouze virtuálně. Na konferenci DEF CON naplánované přednášky jsou již k dispozici na DEF CON Media Serveru a na YouTube.

Ladislav Hagara | Komentářů: 1
6.8. 07:33 | Nová verze

Po více než pěti letech byla vydána nová verze 1.7 multiplatformního grafického editoru Pinta (Wikipedie). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
6.8. 00:33 | Komunita

V září loňského roku Richard Stallman rezignoval na funkci prezidenta Free Software Foundation (FSF). Včera byl zvolen nový prezident. Je jím Geoffrey Knauth (Twitter).

Ladislav Hagara | Komentářů: 9
Dokážete si představit, že by váš hlavní počítač (desktop, notebook) byl v současné době založen na architektuře jiné než x86 (x86_64)? Například ARM, POWER, RISC-V,…
 (10%)
 (12%)
 (57%)
 (15%)
 (5%)
Celkem 187 hlasů
 Komentářů: 13, poslední včera 10:04
Rozcestník
Mate smulu, ze jsme si tu zalozil osobni lamparnu a vy na ni zrovna cumite.
Potrebuju si zanadavat na praci a tady se mi zatim libi.
Kdyz me tu nechate, mozna vam vykecam nejake drobnosti o tom, jak skutecne (ne)funguje (nejen) linux v realnem nasazeni. A ze je na co nadavat.
Nicmene nenecham nitku suchou ani na Oracle, Cisco, SUSE a podobnych priserach, ktere nuti slusne lidi chodit do prace misto toho, aby se valeli na slunicku u vody.
Aktuální zápisy

Oracle daily WTF

26.5.2014 11:30 | Přečteno: 1797× | Linux

Kryptozapisek o kvalite Oracle databaze.
Budeme potrebovat zakerne SQL:
CREATE OR REPLACE TYPE parent_type AUTHID CURRENT_USER AS OBJECT (
    id              NUMBER(38)
) NOT FINAL NOT INSTANTIABLE;
/

CREATE OR REPLACE TYPE subtype_a AUTHID CURRENT_USER UNDER parent_type (
);
/

CREATE OR REPLACE TYPE subtype_b AUTHID CURRENT_USER UNDER parent_type (
);
/

CREATE TABLE t_parents (
    parent          parent_type
);

INSERT INTO t_parents VALUES (subtype_a(1));
INSERT INTO t_parents VALUES (NULL);
INSERT INTO t_parents VALUES (subtype_b(2));

COMMIT;
/
a smrtici Perl kod:
use DBI;
use DBD::Oracle qw(:ora_types);

my $dbh = DBI->connect("dbi:Oracle:SID","jmeno","heslo");
my $sth = $dbh->prepare("SELECT * FROM t_parents");
$sth->execute();
while (my @r = $sth->fetchrow_array) {}
$dbh->disconnect;
A co jsme to uvarili?
OCI-21500: internal error code, arguments: [kodrsobj1], [], [], [], [], [], [], []
Zatim cekam na reopen SR. Musel jsem to tem lamickam na supportu prepsat do plain C a to nemam OCI zrovna v lasce.        

Hodnocení: 86 %

        špatnédobré        

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

Komentáře

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: 38 | 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: 38 | 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: 38 | blog: Alkoholik
Rozbalit Rozbalit vše Re: Oracle daily WTF
Javu ja rad.
26.5.2014 12:16 alkoholik | skóre: 38 | 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: 38 | 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: 38 | 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: 49 | 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: 49 | 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: 38 | 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: 49 | 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: 38 | 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: 38 | 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: 38 | 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

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