Inserting using SQL descriptors in ECPG in different versions of Linux

From: Anders Nilsson <anders(dot)nilsson(at)noaa(dot)gov>
To: pgsql-interfaces(at)postgresql(dot)org
Subject: Inserting using SQL descriptors in ECPG in different versions of Linux
Date: 2017-09-28 18:14:39
Message-ID: CAEx11v5ScGENAcDVfMVuKMaBMMGkdrdqtSgAmfF_NaBihKkY+g@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-interfaces

Hi all,

I'm working on migrating a project from Centos-6 Linux (gcc 4.4.7) to
Centos-7 (gcc 4.8.5) Linux. The postgreSQL version is staying the same, at
9.2.x. Everything is going fine, except for one section of our ECPG/C code
which uses SQL descriptor areas to insert a dynamic number of columns into
a table. Demonstration code can be found below.

The following code compiles and runs fine without error messages on the
Centos-6 box, but on the Centos-7 box, the execution of the prepared query
with descriptor returns successful but without inserting any records and
displaying the "No record actually inserted" message. Set PGUSER/PGDATABASE
accordingly to run.

Any idea what I might be doing wrong?

Thanks,
Anders

(P.S. The presence of that descriptor placeholder variable is to get it to
compile. I'm not exactly sure if that is the best way of going about it. )

---------------------------------------------------------------------
descriptor.pgc
---------------------------------------------------------------------
// Includes
#include <stdlib.h>

int main ( int argc, char *argv[] )
{
// Declared variables
exec sql begin declare section;

long column; // Column index
char insert_desc[32]; // Descriptor placeholder variable
int is_null; // NULL indicator
long number_columns; // Number of table columns
char statement[256]; // Query statement
long value_long ; // Test value
double value_double ; // Test value

exec sql end declare section;

// Initialize variables
insert_desc[0] = 0 ; // Dummy placeholder variable for descriptor name
number_columns = 3 ;

// Connect to database
exec sql connect to default;
if ( sqlca.sqlcode ) { printf( "Unable to connect to database:%s\n",
sqlca.sqlerrm.sqlerrmc ); }
// Create scratch table to test on
sprintf ( statement, "create temporary table scratch ( value1 integer, "
"value2 double
precision, "
"value3 double
precision )" );
exec sql execute immediate :statement;
if ( sqlca.sqlcode ) { printf( "Unable to create temporary table
scratch:%s\n", sqlca.sqlerrm.sqlerrmc ); }

// Prepare statement
strcpy ( statement, "insert into scratch ( value1, value2, value3 ) "
"values ( ?, ?, ? )" );
exec sql prepare sid1 from :statement;
if ( sqlca.sqlcode ) { printf( "Unable to prepare statement
\"%s\":%s\n", statement, sqlca.sqlerrm.sqlerrmc ); }

// Allocate descriptor
exec sql allocate descriptor insert_desc;
if ( sqlca.sqlcode ) { printf( "Unable to allocate descriptor:%s\n",
sqlca.sqlerrm.sqlerrmc ); }

// Set number of columns
exec sql set descriptor insert_desc COUNT = :number_columns;
if ( sqlca.sqlcode ) { printf( "Unable to set descriptor size:%s\n",
sqlca.sqlerrm.sqlerrmc ); }

// Populate columns
column = 1;
is_null = 0;
value_long = 60799;
exec sql set descriptor insert_desc VALUE :column
DATA = :value_long,
INDICATOR = :is_null ;
if ( sqlca.sqlcode ) { printf( "Unable to set column %ld descriptor
data:%s\n", column, sqlca.sqlerrm.sqlerrmc ); }

column++;
is_null = 0;
value_double = -45.78;
exec sql set descriptor insert_desc VALUE :column
DATA = :value_double,
INDICATOR = :is_null ;
if ( sqlca.sqlcode ) { printf( "Unable to set column %ld descriptor
data:%s\n", column, sqlca.sqlerrm.sqlerrmc ); }

column++;
is_null = 0;
value_double = 559997.4;
exec sql set descriptor insert_desc VALUE :column
DATA = :value_double,
INDICATOR = :is_null ;
if ( sqlca.sqlcode ) { printf( "Unable to set column %ld descriptor
data:%s\n", column, sqlca.sqlerrm.sqlerrmc ); }

// Insert record
exec sql execute sid1 using descriptor insert_desc;
if ( sqlca.sqlcode ) { printf( "Unable to insert record:%s\n",
sqlca.sqlerrm.sqlerrmc ); }
// Checking record count
if ( sqlca.sqlerrd[2] == 0 ) { printf( "No record actually inserted\n"
); }

// Free allocated memory
exec sql deallocate descriptor insert_desc;
exec sql free sid1;

// Disconnect from database
exec sql disconnect;
if ( sqlca.sqlcode ) { printf( "Unable to disconnect from
database:%s\n", sqlca.sqlerrm.sqlerrmc ); }

// Done
exit ( 0 );
}

------------------------------------------------------------------
Makefile:
------------------------------------------------------------------
PG=/usr
PG_LIB=$(PG)/lib64
PGM=descriptor
.SUFFIXES: .o .pgc .c
.pgc.c:
<tab>$(PG)/bin/ecpg -t $<
.c.o:
<tab>$(CC) -g -Wall -I$(PG)/include -c $<
$(PGM): $(PGM).o
<tab>$(CC) -o $@ $(PGM).o -L$(PG_LIB) -lecpg
clean:
<tab>rm -f $(PGM).o $(PGM)
-------------------------------------------------------------------

Responses

Browse pgsql-interfaces by date

  From Date Subject
Next Message Michael Meskes 2017-10-01 08:44:23 Re: Inserting using SQL descriptors in ECPG in different versions of Linux
Previous Message Dave Cramer 2017-08-01 19:01:59 JDBC 42.1.4 released