mirror of https://github.com/postgres/postgres
parent
3881cbd2f6
commit
c6cf21825a
@ -1,19 +0,0 @@ |
|||||||
#
|
|
||||||
# Makefile
|
|
||||||
#
|
|
||||||
#
|
|
||||||
TARGET = pginsert
|
|
||||||
CFLAGS = -g -Wall -I/u/postgres95/include
|
|
||||||
LIBS = -L/u/postgres95/lib -lpq
|
|
||||||
|
|
||||||
$(TARGET) : pginsert.o pginterface.o halt.o |
|
||||||
$(CC) -o $(TARGET) $(XFLAGS) $(CFLAGS) \
|
|
||||||
pginsert.o pginterface.o halt.o $(LIBS)
|
|
||||||
|
|
||||||
clean: |
|
||||||
rm -f *.o $(TARGET) log core
|
|
||||||
|
|
||||||
install: |
|
||||||
make clean
|
|
||||||
make CFLAGS=-O
|
|
||||||
install -s -o bin -g bin $(TARGET) /usr/local/bin
|
|
@ -1,58 +0,0 @@ |
|||||||
/*
|
|
||||||
** |
|
||||||
** halt.c |
|
||||||
** |
|
||||||
** This is used to print out error messages and exit |
|
||||||
*/ |
|
||||||
|
|
||||||
#include <varargs.h> |
|
||||||
#include <signal.h> |
|
||||||
#include <stdio.h> |
|
||||||
#include <stdlib.h> |
|
||||||
#include <string.h> |
|
||||||
#include <errno.h> |
|
||||||
|
|
||||||
|
|
||||||
/*-------------------------------------------------------------------------
|
|
||||||
** |
|
||||||
** halt - print error message, and call clean up routine or exit |
|
||||||
** |
|
||||||
**------------------------------------------------------------------------*/ |
|
||||||
|
|
||||||
/*VARARGS*/ |
|
||||||
void halt(va_alist) |
|
||||||
va_dcl |
|
||||||
{ |
|
||||||
va_list arg_ptr; |
|
||||||
char *format, *pstr; |
|
||||||
void (*sig_func)(); |
|
||||||
|
|
||||||
va_start(arg_ptr); |
|
||||||
format = va_arg(arg_ptr,char *); |
|
||||||
if (strncmp(format,"PERROR", 6) != 0) |
|
||||||
vfprintf(stderr,format,arg_ptr); |
|
||||||
else |
|
||||||
{ |
|
||||||
for (pstr=format+6; *pstr == ' ' || *pstr == ':'; pstr++) |
|
||||||
; |
|
||||||
vfprintf(stderr,pstr,arg_ptr); |
|
||||||
perror(""); |
|
||||||
}
|
|
||||||
va_end(arg_ptr); |
|
||||||
fflush(stderr); |
|
||||||
|
|
||||||
/* call one clean up function if defined */ |
|
||||||
if ( (sig_func = signal(SIGTERM, SIG_DFL)) != SIG_DFL && |
|
||||||
sig_func != SIG_IGN) |
|
||||||
(*sig_func)(0); |
|
||||||
else if ( (sig_func = signal(SIGHUP, SIG_DFL)) != SIG_DFL && |
|
||||||
sig_func != SIG_IGN) |
|
||||||
(*sig_func)(0); |
|
||||||
else if ( (sig_func = signal(SIGINT, SIG_DFL)) != SIG_DFL && |
|
||||||
sig_func != SIG_IGN) |
|
||||||
(*sig_func)(0); |
|
||||||
else if ( (sig_func = signal(SIGQUIT, SIG_DFL)) != SIG_DFL && |
|
||||||
sig_func != SIG_IGN) |
|
||||||
(*sig_func)(0); |
|
||||||
exit(1); |
|
||||||
} |
|
@ -1,7 +0,0 @@ |
|||||||
/*
|
|
||||||
** halt.h |
|
||||||
** |
|
||||||
*/ |
|
||||||
|
|
||||||
void halt(); |
|
||||||
|
|
@ -1,98 +0,0 @@ |
|||||||
/*
|
|
||||||
* insert.c |
|
||||||
* |
|
||||||
*/ |
|
||||||
|
|
||||||
#include <stdio.h> |
|
||||||
#include <signal.h> |
|
||||||
#include <time.h> |
|
||||||
#include <halt.h> |
|
||||||
#include <libpq-fe.h> |
|
||||||
#include "pginterface.h" |
|
||||||
|
|
||||||
int main(int argc, char **argv) |
|
||||||
{ |
|
||||||
char query[4000]; |
|
||||||
int row =1; |
|
||||||
int aint; |
|
||||||
float afloat; |
|
||||||
double adouble; |
|
||||||
char achar[11], achar16[17], abpchar[11], avarchar[51], atext[51]; |
|
||||||
time_t aabstime; |
|
||||||
|
|
||||||
if (argc != 2) |
|
||||||
halt("Usage: %s database\n",argv[0]); |
|
||||||
|
|
||||||
connectdb(argv[1],NULL,NULL,NULL,NULL); |
|
||||||
|
|
||||||
skip_query_errors = 1; |
|
||||||
doquery("DROP TABLE testfetch"); |
|
||||||
skip_query_errors = 0; |
|
||||||
|
|
||||||
doquery("\
|
|
||||||
CREATE TABLE testfetch( \
|
|
||||||
aint int4, \
|
|
||||||
afloat float4, \
|
|
||||||
adouble float8, \
|
|
||||||
achar char, \
|
|
||||||
achar16 char16, \
|
|
||||||
abpchar char(10), \
|
|
||||||
avarchar varchar(50), \
|
|
||||||
atext text, \
|
|
||||||
aabstime abstime) \
|
|
||||||
"); |
|
||||||
|
|
||||||
while(1) |
|
||||||
{ |
|
||||||
sprintf(query,"INSERT INTO testfetch VALUES ( \
|
|
||||||
%d, \
|
|
||||||
2322.12, \
|
|
||||||
'923121.0323'::float8, \
|
|
||||||
'A', \
|
|
||||||
'Betty', \
|
|
||||||
'Charley', \
|
|
||||||
'Doug', \
|
|
||||||
'Ernie', \
|
|
||||||
'now' )", row); |
|
||||||
doquery(query); |
|
||||||
|
|
||||||
doquery("BEGIN WORK"); |
|
||||||
doquery("DECLARE c_testfetch BINARY CURSOR FOR \
|
|
||||||
SELECT * FROM testfetch"); |
|
||||||
|
|
||||||
doquery("FETCH ALL IN c_testfetch"); |
|
||||||
|
|
||||||
while (fetch( |
|
||||||
&aint,
|
|
||||||
&afloat,
|
|
||||||
&adouble,
|
|
||||||
achar,
|
|
||||||
achar16,
|
|
||||||
abpchar,
|
|
||||||
avarchar,
|
|
||||||
atext, |
|
||||||
&aabstime) != END_OF_TUPLES) |
|
||||||
printf("int %d\nfloat %f\ndouble %f\nchar %s\nchar16 %s\n\
|
|
||||||
bpchar %s\nvarchar %s\ntext %s\nabstime %s", |
|
||||||
aint,
|
|
||||||
afloat,
|
|
||||||
adouble,
|
|
||||||
achar,
|
|
||||||
achar16,
|
|
||||||
abpchar,
|
|
||||||
avarchar, |
|
||||||
atext, |
|
||||||
ctime(&aabstime)); |
|
||||||
|
|
||||||
|
|
||||||
doquery("CLOSE c_testfetch"); |
|
||||||
doquery("COMMIT WORK"); |
|
||||||
printf("--- %-d rows inserted so far\n",row); |
|
||||||
|
|
||||||
row++; |
|
||||||
} |
|
||||||
|
|
||||||
disconnectdb(); |
|
||||||
return 0; |
|
||||||
} |
|
||||||
|
|
@ -1,154 +0,0 @@ |
|||||||
/*
|
|
||||||
* pginterface.c |
|
||||||
* |
|
||||||
*/ |
|
||||||
|
|
||||||
#include <stdio.h> |
|
||||||
#include <string.h> |
|
||||||
#include <signal.h> |
|
||||||
#include <stdarg.h> |
|
||||||
|
|
||||||
#include <halt.h> |
|
||||||
#include <libpq-fe.h> |
|
||||||
#include "pginterface.h" |
|
||||||
|
|
||||||
static void sig_disconnect(); |
|
||||||
static void set_signals(); |
|
||||||
|
|
||||||
#define NUL '\0' |
|
||||||
|
|
||||||
/* GLOBAL VARIABLES */ |
|
||||||
static PGconn* conn; |
|
||||||
static PGresult* res = NULL; |
|
||||||
int skip_query_errors = 0; |
|
||||||
|
|
||||||
/* LOCAL VARIABLES */ |
|
||||||
static sigset_t block_sigs, unblock_sigs; |
|
||||||
static int tuple; |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** connectdb - returns PGconn structure |
|
||||||
** |
|
||||||
*/ |
|
||||||
PGconn *connectdb( char *dbName, |
|
||||||
char *pghost, |
|
||||||
char *pgport, |
|
||||||
char *pgoptions, |
|
||||||
char *pgtty) |
|
||||||
{ |
|
||||||
/* make a connection to the database */ |
|
||||||
conn = PQsetdb(pghost, pgport, pgoptions, pgtty, dbName); |
|
||||||
if (PQstatus(conn) == CONNECTION_BAD) |
|
||||||
halt("Connection to database '%s' failed.\n%s\n", dbName, |
|
||||||
PQerrorMessage(conn)); |
|
||||||
set_signals(); |
|
||||||
return conn; |
|
||||||
} |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** disconnectdb |
|
||||||
** |
|
||||||
*/ |
|
||||||
void disconnectdb() |
|
||||||
{ |
|
||||||
PQfinish(conn); |
|
||||||
} |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** doquery - returns PGresult structure |
|
||||||
** |
|
||||||
*/ |
|
||||||
PGresult *doquery(char *query) |
|
||||||
{ |
|
||||||
if (res != NULL) |
|
||||||
PQclear(res); |
|
||||||
|
|
||||||
sigprocmask(SIG_SETMASK,&block_sigs,NULL); |
|
||||||
res = PQexec(conn, query); |
|
||||||
sigprocmask(SIG_SETMASK,&unblock_sigs,NULL); |
|
||||||
|
|
||||||
if (skip_query_errors == 0 && |
|
||||||
(res == NULL || |
|
||||||
PQresultStatus(res) == PGRES_BAD_RESPONSE || |
|
||||||
PQresultStatus(res) == PGRES_NONFATAL_ERROR || |
|
||||||
PQresultStatus(res) == PGRES_FATAL_ERROR)) |
|
||||||
{ |
|
||||||
if (res != NULL) |
|
||||||
fprintf(stderr,"query error: %s\n",PQcmdStatus(res)); |
|
||||||
else fprintf(stderr,"connection error: %s\n",PQerrorMessage(conn)); |
|
||||||
PQfinish(conn); |
|
||||||
halt("failed request: %s\n", query); |
|
||||||
} |
|
||||||
tuple = 0; |
|
||||||
return res; |
|
||||||
} |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** fetch - returns tuple number (starts at 0), or the value END_OF_TUPLES |
|
||||||
** NULL pointers are skipped |
|
||||||
** |
|
||||||
*/ |
|
||||||
int fetch(void *param, ...) |
|
||||||
{ |
|
||||||
va_list ap; |
|
||||||
int arg, num_args; |
|
||||||
|
|
||||||
num_args = PQnfields(res); |
|
||||||
|
|
||||||
if (tuple >= PQntuples(res)) |
|
||||||
return END_OF_TUPLES; |
|
||||||
va_start(ap, param); |
|
||||||
for (arg = 0; arg < num_args; arg++) |
|
||||||
{ |
|
||||||
if (param != NULL) |
|
||||||
{ |
|
||||||
if (PQfsize(res, arg) == -1) |
|
||||||
{ |
|
||||||
memcpy(param,PQgetvalue(res,tuple,arg),PQgetlength(res,tuple,arg)); |
|
||||||
((char *)param)[PQgetlength(res,tuple,arg)] = NUL; |
|
||||||
} |
|
||||||
else |
|
||||||
memcpy(param,PQgetvalue(res,tuple,arg),PQfsize(res,arg)); |
|
||||||
} |
|
||||||
param = va_arg(ap, char *); |
|
||||||
} |
|
||||||
va_end(ap); |
|
||||||
return tuple++; |
|
||||||
} |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** sig_disconnect |
|
||||||
** |
|
||||||
*/ |
|
||||||
static void sig_disconnect() |
|
||||||
{ |
|
||||||
fprintf(stderr,"exiting...\n"); |
|
||||||
PQfinish(conn); |
|
||||||
exit(1); |
|
||||||
} |
|
||||||
|
|
||||||
/*
|
|
||||||
** |
|
||||||
** set_signals |
|
||||||
** |
|
||||||
*/ |
|
||||||
static void set_signals() |
|
||||||
{ |
|
||||||
sigemptyset(&block_sigs); |
|
||||||
sigemptyset(&unblock_sigs); |
|
||||||
sigaddset(&block_sigs,SIGTERM); |
|
||||||
sigaddset(&block_sigs,SIGHUP); |
|
||||||
sigaddset(&block_sigs,SIGINT); |
|
||||||
/* sigaddset(&block_sigs,SIGQUIT); no block */ |
|
||||||
sigprocmask(SIG_SETMASK,&unblock_sigs,NULL); |
|
||||||
signal(SIGTERM,sig_disconnect); |
|
||||||
signal(SIGHUP,sig_disconnect); |
|
||||||
signal(SIGINT,sig_disconnect); |
|
||||||
signal(SIGQUIT,sig_disconnect); |
|
||||||
} |
|
||||||
|
|
@ -1,12 +0,0 @@ |
|||||||
/*
|
|
||||||
* pglib.h |
|
||||||
* |
|
||||||
*/ |
|
||||||
|
|
||||||
PGresult *doquery(char *query); |
|
||||||
PGconn *connectdb(); |
|
||||||
void disconnectdb(); |
|
||||||
int fetch(void *param, ...); |
|
||||||
int skip_query_errors; |
|
||||||
|
|
||||||
#define END_OF_TUPLES (-1) |
|
Loading…
Reference in new issue