mirror of
https://github.com/postgres/postgres.git
synced 2025-06-26 12:21:12 +03:00
289 lines
7.4 KiB
C
289 lines
7.4 KiB
C
/* Processed by ecpg (regression mode) */
|
|
/* These include files are added by the preprocessor */
|
|
#include <ecpglib.h>
|
|
#include <ecpgerrno.h>
|
|
#include <sqlca.h>
|
|
/* End of automatic include section */
|
|
#define ECPGdebug(X,Y) ECPGdebug((X)+100,(Y))
|
|
|
|
#line 1 "array_of_struct.pgc"
|
|
#include <stdio.h>
|
|
|
|
|
|
#line 1 "regression.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#line 3 "array_of_struct.pgc"
|
|
|
|
|
|
/* exec sql whenever sqlerror sqlprint ; */
|
|
#line 5 "array_of_struct.pgc"
|
|
|
|
/* exec sql whenever sql_warning sqlprint ; */
|
|
#line 6 "array_of_struct.pgc"
|
|
|
|
/* exec sql whenever not found sqlprint ; */
|
|
#line 7 "array_of_struct.pgc"
|
|
|
|
|
|
typedef struct {
|
|
#line 12 "array_of_struct.pgc"
|
|
struct varchar_1 { int len; char arr[ 50 ]; } name ;
|
|
|
|
#line 13 "array_of_struct.pgc"
|
|
int phone ;
|
|
} customer ;
|
|
#line 14 "array_of_struct.pgc"
|
|
|
|
|
|
typedef struct ind {
|
|
#line 19 "array_of_struct.pgc"
|
|
short name_ind ;
|
|
|
|
#line 20 "array_of_struct.pgc"
|
|
short phone_ind ;
|
|
} cust_ind ;
|
|
#line 21 "array_of_struct.pgc"
|
|
|
|
|
|
int main()
|
|
{
|
|
/* exec sql begin declare section */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
#line 30 "array_of_struct.pgc"
|
|
struct varchar_2 { int len; char arr[ 50 ]; } name ;
|
|
|
|
#line 31 "array_of_struct.pgc"
|
|
int phone ;
|
|
} customer2 ;
|
|
|
|
#line 32 "array_of_struct.pgc"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#line 26 "array_of_struct.pgc"
|
|
customer custs1 [ 10 ] ;
|
|
|
|
#line 27 "array_of_struct.pgc"
|
|
cust_ind inds [ 10 ] ;
|
|
|
|
#line 33 "array_of_struct.pgc"
|
|
customer2 custs2 [ 10 ] ;
|
|
|
|
#line 38 "array_of_struct.pgc"
|
|
struct customer3 {
|
|
#line 36 "array_of_struct.pgc"
|
|
struct varchar_3 { int len; char arr[ 50 ]; } name ;
|
|
|
|
#line 37 "array_of_struct.pgc"
|
|
int phone ;
|
|
} custs3 [ 10 ] ;
|
|
|
|
#line 43 "array_of_struct.pgc"
|
|
struct customer4 {
|
|
#line 41 "array_of_struct.pgc"
|
|
struct varchar_4 { int len; char arr[ 50 ]; } name ;
|
|
|
|
#line 42 "array_of_struct.pgc"
|
|
int phone ;
|
|
} custs4 ;
|
|
|
|
#line 44 "array_of_struct.pgc"
|
|
int r ;
|
|
|
|
#line 45 "array_of_struct.pgc"
|
|
struct varchar_5 { int len; char arr[ 50 ]; } onlyname [ 2 ] ;
|
|
/* exec sql end declare section */
|
|
#line 46 "array_of_struct.pgc"
|
|
|
|
|
|
ECPGdebug(1, stderr);
|
|
|
|
{ ECPGconnect(__LINE__, 0, "regress1" , NULL, NULL , NULL, 0);
|
|
#line 50 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 50 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 50 "array_of_struct.pgc"
|
|
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "create table customers ( c varchar ( 50 ) , p int )", ECPGt_EOIT, ECPGt_EORT);
|
|
#line 52 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 52 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 52 "array_of_struct.pgc"
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "insert into customers values ( 'John Doe' , '12345' )", ECPGt_EOIT, ECPGt_EORT);
|
|
#line 53 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 53 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 53 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 53 "array_of_struct.pgc"
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "insert into customers values ( 'Jane Doe' , '67890' )", ECPGt_EOIT, ECPGt_EORT);
|
|
#line 54 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 54 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 54 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 54 "array_of_struct.pgc"
|
|
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "select * from customers limit 2", ECPGt_EOIT,
|
|
ECPGt_varchar,&(custs1->name),(long)50,(long)10,sizeof( customer ),
|
|
ECPGt_short,&(inds->name_ind),(long)1,(long)10,sizeof( struct ind ),
|
|
ECPGt_int,&(custs1->phone),(long)1,(long)10,sizeof( customer ),
|
|
ECPGt_short,&(inds->phone_ind),(long)1,(long)10,sizeof( struct ind ), ECPGt_EORT);
|
|
#line 56 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 56 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 56 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 56 "array_of_struct.pgc"
|
|
|
|
printf("custs1:\n");
|
|
for (r = 0; r < 2; r++)
|
|
{
|
|
printf( "name - %s\n", custs1[r].name.arr );
|
|
printf( "phone - %d\n", custs1[r].phone );
|
|
}
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "select * from customers limit 2", ECPGt_EOIT,
|
|
ECPGt_varchar,&(custs2->name),(long)50,(long)10,sizeof( customer2 ),
|
|
ECPGt_short,&(inds->name_ind),(long)1,(long)10,sizeof( struct ind ),
|
|
ECPGt_int,&(custs2->phone),(long)1,(long)10,sizeof( customer2 ),
|
|
ECPGt_short,&(inds->phone_ind),(long)1,(long)10,sizeof( struct ind ), ECPGt_EORT);
|
|
#line 64 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 64 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 64 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 64 "array_of_struct.pgc"
|
|
|
|
printf("\ncusts2:\n");
|
|
for (r = 0; r < 2; r++)
|
|
{
|
|
printf( "name - %s\n", custs2[r].name.arr );
|
|
printf( "phone - %d\n", custs2[r].phone );
|
|
}
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "select * from customers limit 2", ECPGt_EOIT,
|
|
ECPGt_varchar,&(custs3->name),(long)50,(long)10,sizeof( struct customer3 ),
|
|
ECPGt_short,&(inds->name_ind),(long)1,(long)10,sizeof( struct ind ),
|
|
ECPGt_int,&(custs3->phone),(long)1,(long)10,sizeof( struct customer3 ),
|
|
ECPGt_short,&(inds->phone_ind),(long)1,(long)10,sizeof( struct ind ), ECPGt_EORT);
|
|
#line 72 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 72 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 72 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 72 "array_of_struct.pgc"
|
|
|
|
printf("\ncusts3:\n");
|
|
for (r = 0; r < 2; r++)
|
|
{
|
|
printf( "name - %s\n", custs3[r].name.arr );
|
|
printf( "phone - %d\n", custs3[r].phone );
|
|
}
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "select * from customers limit 1", ECPGt_EOIT,
|
|
ECPGt_varchar,&(custs4.name),(long)50,(long)1,sizeof( struct customer4 ),
|
|
ECPGt_short,&(inds[0].name_ind),(long)1,(long)1,sizeof( struct ind ),
|
|
ECPGt_int,&(custs4.phone),(long)1,(long)1,sizeof( struct customer4 ),
|
|
ECPGt_short,&(inds[0].phone_ind),(long)1,(long)1,sizeof( struct ind ), ECPGt_EORT);
|
|
#line 80 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 80 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 80 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 80 "array_of_struct.pgc"
|
|
|
|
printf("\ncusts4:\n");
|
|
printf( "name - %s\n", custs4.name.arr );
|
|
printf( "phone - %d\n", custs4.phone );
|
|
|
|
{ ECPGdo(__LINE__, 0, 1, NULL, 0, ECPGst_normal, "select c from customers limit 2", ECPGt_EOIT,
|
|
ECPGt_varchar,(onlyname),(long)50,(long)2,sizeof(struct varchar_5),
|
|
ECPGt_NO_INDICATOR, NULL , 0L, 0L, 0L, ECPGt_EORT);
|
|
#line 85 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode == ECPG_NOT_FOUND) sqlprint();
|
|
#line 85 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 85 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 85 "array_of_struct.pgc"
|
|
|
|
printf("\nname:\n");
|
|
for (r = 0; r < 2; r++)
|
|
{
|
|
printf( "name - %s\n", onlyname[r].arr );
|
|
}
|
|
|
|
{ ECPGdisconnect(__LINE__, "ALL");
|
|
#line 92 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlwarn[0] == 'W') sqlprint();
|
|
#line 92 "array_of_struct.pgc"
|
|
|
|
if (sqlca.sqlcode < 0) sqlprint();}
|
|
#line 92 "array_of_struct.pgc"
|
|
|
|
|
|
return( 0 );
|
|
}
|