Re: Converting a TimestampTz into a C# DateTime - Mailing list pgsql-general

From Jerome Wagner
Subject Re: Converting a TimestampTz into a C# DateTime
Date
Msg-id CA+=V_fMhLGf7naAuv62NQKqAOn8ZYkpm8ObpYcRu_bK74nF-wQ@mail.gmail.com
Whole thread Raw
In response to Re: Converting a TimestampTz into a C# DateTime  (Albe Laurenz <laurenz.albe@wien.gv.at>)
Responses Re: Converting a TimestampTz into a C# DateTime  (Tom Lane <tgl@sss.pgh.pa.us>)
Re: Converting a TimestampTz into a C# DateTime  (Albe Laurenz <laurenz.albe@wien.gv.at>)
List pgsql-general
Hello,
seeing you answer I have a question for which I found no answer a few weeks ago : is there a way to know at runtime which internal representation timestamps have ?
I am trying to deal with the COPY binary protocol with only SQL access to the remote server and would like to find a way to know the internal representation to read / write the correct timestamps.
Thanks for your help  !

On Mon, Nov 14, 2016 at 1:12 PM, Albe Laurenz <laurenz.albe@wien.gv.at> wrote:
valeriof wrote:
> I'm handling a TimestampTz value inside a plugin to stream WAL changes to a
> .NET client application. What I'm trying to do is to return all possible
> column changes as binary (don't like to have Postgres handle the conversion
> to string as I may need to have access to the bytes at the client level). In
> case of a TimestampTz, is it possible to return the 8-bytes long integer and
> then from the C# application convert the value to Ticks?

Sure, if you know how it is stored internally.

One of your problems will be that the format depends on whether PostgreSQL
was configured with --disable-integer-datetimes or not.

With that switch, a timestamp is a double precision value, otherwise a
64-bit integer value. In the former case, it measures seconds after
midnight 2000-01-01, while in the latter case it measures microseconds
after that timestamp.

Yours,
Laurenz Albe

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

pgsql-general by date:

Previous
From: Adrian Klaver
Date:
Subject: Re: Syncing Data of data type BLOB into Postgres- Bytea
Next
From: Tom Lane
Date:
Subject: Re: Converting a TimestampTz into a C# DateTime