--- sql/oracle/parser3oracle.C 2003/09/29 06:15:27 1.35 +++ sql/oracle/parser3oracle.C 2003/10/30 12:38:18 1.40 @@ -7,7 +7,7 @@ 2001.07.30 using Oracle 8.1.6 [@test tested with Oracle 7.x.x] */ -static const char *RCSId="$Id: parser3oracle.C,v 1.35 2003/09/29 06:15:27 paf Exp $"; +static const char *RCSId="$Id: parser3oracle.C,v 1.40 2003/10/30 12:38:18 paf Exp $"; #include "config_includes.h" @@ -104,11 +104,17 @@ static char *lsplit(char **string_ref, c return result; } -static const char *options2env(char *options) { +static const char *options2env(char *options, bool* LowerCaseColumnNames) { while(options) { if(char *key=lsplit(&options, '&')) { if(*key) { if(char *value=lsplit(key, '=')) { + if( strcmp( key, "LowerCaseColumnNames" ) == 0 ) { + if( LowerCaseColumnNames ) + *LowerCaseColumnNames = atoi(value)!=0; + continue; + } + bool do_append=key[strlen(key)-1]=='+'; // PATH+= if(do_append) key[strlen(key)-1]=0; // remove trailing + @@ -138,6 +144,8 @@ struct OracleSQL_connection_struct { OCIError *errhp; OCISvcCtx *svchp; OCISession *usrhp; + + bool bLowerCaseColumnNames; }; struct OracleSQL_query_lobs { @@ -206,7 +214,7 @@ public: const char *error=dlopen_file_spec? dlink(dlopen_file_spec):"client library column is empty"; if(!error) { - error=options2env(options); + error=options2env(options, 0); if(!error) OCIInitialize((ub4)OCI_THREADED/*| OCI_OBJECT*/, (dvoid *)0, @@ -237,6 +245,7 @@ public: // connections are cross-request, do not use services._alloc [linked with request] OracleSQL_connection_struct &cs= *(OracleSQL_connection_struct *)::calloc(sizeof(OracleSQL_connection_struct), 1); + cs.bLowerCaseColumnNames = true; char *user=used_only_in_connect_url; char *service=lsplit(user, '@'); @@ -246,7 +255,7 @@ public: if(!(user && pwd && service)) services._throw("mailformed connect part, must be 'user:pass@service'"); - if(const char *error=options2env(options)) + if(const char *error=options2env(options, &cs.bLowerCaseColumnNames)) services._throw(error); if(setjmp(cs.mark)) @@ -624,7 +633,7 @@ private: // private funcs ub2 dtype; text *col_name; - struct { + struct Col { ub2 type; char *str; OCILobLocator *var; @@ -661,11 +670,16 @@ private: // private funcs (dvoid**) &col_name, (ub4 *) &col_name_len, (ub4)OCI_ATTR_NAME, (OCIError *)cs.errhp)); + Col& col=cols[column_count-1]; { - size_t size=(size_t)col_name_len; - char *ptr=(char *)services.malloc_atomic(size); - tolower(ptr, (char *)col_name, size); - check(cs, handlers.add_column(cs.sql_error, ptr, size)); + size_t length=(size_t)col_name_len; + char *ptr=(char *)services.malloc_atomic(length+1); + if( cs.bLowerCaseColumnNames ) + tolower(ptr, (char *)col_name, length); + else + memcpy(ptr, col_name, length); + ptr[length]=0; + check(cs, handlers.add_column(cs.sql_error, ptr, length)); } ub2 coerce_type=dtype; @@ -676,7 +690,7 @@ private: // private funcs case SQLT_CLOB: { check(cs, "alloc output var desc", OCIDescriptorAlloc( - (dvoid *)cs.envhp, (dvoid **)(ptr=&cols[column_count-1].var), + (dvoid *)cs.envhp, (dvoid **)(ptr=&col.var), (ub4)OCI_DTYPE_LOB, 0, (dvoid **)0)); @@ -685,17 +699,17 @@ private: // private funcs } default: coerce_type=SQLT_STR; - ptr=cols[column_count-1].str=(char *)services.malloc_atomic(MAX_OUT_STRING_LENGTH+1); + ptr=col.str=(char *)services.malloc_atomic(MAX_OUT_STRING_LENGTH+1); size=MAX_OUT_STRING_LENGTH; break; } - cols[column_count-1].type=coerce_type; + col.type=coerce_type; - check(cs, "DefineByPos", OCIDefineByPos( - stmthp, &cols[column_count-1].def, cs.errhp, + col.def=0; check(cs, "DefineByPos", OCIDefineByPos( + stmthp, &col.def, cs.errhp, column_count, (ub1 *) ptr, size, - coerce_type, (dvoid *) &cols[column_count-1].indicator, + coerce_type, (dvoid *) &col.indicator, (ub2 *)0, (ub2 *)0, OCI_DEFAULT)); } @@ -711,7 +725,7 @@ private: // private funcs if(row>=offset) { check(cs, handlers.add_row(cs.sql_error)); for(int i=0; i