Search Postgresql Archives

- pgaql long value corrupted using htons

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



1. I am having trouble writing long values via c interface .testlibqp-dt.c  is attached.
. 2 is being inserted as 8589934592.


qsf=> select * from t1;
   curdate   |  strf  |        intf        |         tm_new         | txnid 
------------+--------+--------------------+------------------------+-------
1999-01-10 | hello2 |8589934592 | 1999-01-08 04:05:06-05 |     3

I tried htobe64 but that didn't help either.
Any advise would be appreciated.

2. I am using string for data and timestamp and it seems to work.

I found functions like TimestampTzGetDatum,time_t_to_timestamptz in the code 
But it seems they are not exposed to interface.
I have the date time in unix format (via time and gettimeofday). I would prefer to pass those values
in binary, rather than string format. Is there any option to do this ? Or is it easily addable?

thanks
Neeraj

/*
CREATE table t1
(
curdate                 date,
strf                    varchar(10),
intf                    bigint,
tm_new                  timestamptz,
txnid                   smallint
);
 */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <arpa/inet.h>

#include "libpq-fe.h"

static void
exit_nicely(PGconn *conn)
{
	PQfinish(conn);
	exit(1);
}

typedef struct
{
  int 		curdate;
  char		strf[8];
  long		intf;
  int		tm_new;
  short		txnid;
} t1data;

int
main(int argc, char **argv)
{
  char		*user;
  char		*pass;
  char		*dbname;
  char		*host = NULL;
  char		*port = NULL;
  PGconn	*conn;
  PGresult	*res;

  char			insertStmt[512];
  int			result;
  const char* 	stmtName = "t1insert";
  const char*	paramValue[5];
  int			paramLength[5];
  int			paramFormat[5];

  t1data mydata;
  char	date[16];
  char  tm_new[32];
  int ii=0;

  if (argc < 3)
	{
	  fprintf(stderr, "usage: dbname user pass [host][port] \n");
	  exit(1);
	}
  dbname    = argv[1];
  user	    = argv[2];
  pass	    = argv[3];
  if (argc > 3)	host = argv[4];
  if (argc > 4)	port = argv[5];

  /* Make a connection to the database */
  conn = PQsetdbLogin(host, port, NULL, NULL, dbname, user, pass);

  /* Check to see that the backend connection was successfully made */
  if (PQstatus(conn) != CONNECTION_OK)
	{
	  fprintf(stderr, "Connection to database failed: %s", PQerrorMessage(conn));
	  exit_nicely(conn);
	}
  fprintf(stdout, "Connected to database : %s %s\n", user, dbname);

  // prepare insert statement with unique key
  strcpy(insertStmt, "INSERT INTO t1 values ($1, $2, $3, $4, $5);");

  // let the backend prepare statement (it is parsed/planned only once)
  res = PQprepare (conn, stmtName, insertStmt, 1, NULL);
  result = PQresultStatus(res);
  if (result != PGRES_COMMAND_OK)
	{
	  fprintf(stderr, "PQprepare failed: %s : (%d) %s\n", insertStmt, result,PQerrorMessage(conn));
	  PQclear(res);
	  exit_nicely(conn);
	}
  fprintf(stdout, "PQprepare done : %s=%s\n", stmtName, insertStmt);
  PQclear(res);

  // maybe multiple calls to insert data
  strcpy(date, "19990110");
  strcpy(mydata.strf, "hello2");
  mydata.intf = htonl((uint32_t)2);
  strcpy(tm_new, "1999-01-08 04:05:06 EST");
  mydata.txnid = htons(3);

  // set values
  paramValue[0] = date;
  paramValue[1] = mydata.strf;
  paramValue[2] = (char*)&mydata.intf;
  paramValue[3] = tm_new;
  paramValue[4] = (char*)&mydata.txnid;

  // set lengths
  paramLength[0] = 8;
  paramLength[1] = 6;
  paramLength[2] = sizeof(mydata.intf);
  paramLength[3] = strlen(tm_new);
  paramLength[4] = sizeof(mydata.txnid);

  // set format
  paramFormat[0] = 0;
  paramFormat[1] = 0;
  paramFormat[2] = 1;
  paramFormat[3] = 0;
  paramFormat[4] = 1;

  res = PQexecPrepared(conn, stmtName, 5, paramValue, paramLength, paramFormat, 0);
  result = PQresultStatus(res);
  if (result != PGRES_COMMAND_OK)
	{
	  fprintf(stderr, "exec failed: %s : (%d) %s\n", insertStmt, result,PQerrorMessage(conn));
	  PQclear(res);
	  exit_nicely(conn);
	}
  fprintf(stdout, "exec done : %s, $1=(%d)\n", stmtName, ii);

  PQclear(res);

  /* close the connection to the database and cleanup */
  PQfinish(conn);

  return 0;
}
-- 
Sent via pgsql-general mailing list (pgsql-general@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-general

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux