summaryrefslogtreecommitdiff
path: root/libpqpp/column.cpp
diff options
context:
space:
mode:
authorrandomdan <randomdan@localhost>2014-03-03 20:57:27 +0000
committerrandomdan <randomdan@localhost>2014-03-03 20:57:27 +0000
commit1b6aaca3c5eb7e58ebc54242cb76ebe712e2821a (patch)
treec6e389a14de0f8a4ca75e26a1128b71b4c746a2f /libpqpp/column.cpp
parentImprovements to popenrw and add popenrwe for the stderr pipe too (diff)
downloadlibdbpp-postgresql-1b6aaca3c5eb7e58ebc54242cb76ebe712e2821a.tar.bz2
libdbpp-postgresql-1b6aaca3c5eb7e58ebc54242cb76ebe712e2821a.tar.xz
libdbpp-postgresql-1b6aaca3c5eb7e58ebc54242cb76ebe712e2821a.zip
Adds native support for time_duration as a variable type
Pass/retrieve boost::posix_time ptime and time_duration into/out of the db tier
Diffstat (limited to 'libpqpp/column.cpp')
-rw-r--r--libpqpp/column.cpp31
1 files changed, 19 insertions, 12 deletions
diff --git a/libpqpp/column.cpp b/libpqpp/column.cpp
index 90858c8..1f7b932 100644
--- a/libpqpp/column.cpp
+++ b/libpqpp/column.cpp
@@ -2,6 +2,7 @@
#include "selectcommand.h"
#include "error.h"
#include <string.h>
+#include <boost/date_time/posix_time/posix_time.hpp>
PQ::Column::Column(const SelectCommand * s, unsigned int i) :
DB::Column(PQfname(s->execRes, i), i),
@@ -23,7 +24,6 @@ PQ::Column::apply(DB::HandleField & h) const
h.null();
return;
}
- struct tm tm;
switch (oid) {
case 18: //CHAROID:
case 1043: //VARCHAROID:
@@ -44,21 +44,28 @@ PQ::Column::apply(DB::HandleField & h) const
case 701: //FLOAT8OID:
h.floatingpoint(atof(PQgetvalue(sc->execRes, sc->tuple, colNo)));
break;
+ case 704: //TINTERVALOID
case 1083: //TIMEOID:
- memset(&tm, 0, sizeof(tm));
- strptime(PQgetvalue(sc->execRes, sc->tuple, colNo), "%T", &tm);
- h.timestamp(tm);
- break;
- case 1082: //DATEOID:
- memset(&tm, 0, sizeof(tm));
- strptime(PQgetvalue(sc->execRes, sc->tuple, colNo), "%F", &tm);
- h.timestamp(tm);
- break;
+ case 1186: //INTERVALOID
+ {
+ int days = 0, hours = 0, minutes = 0, seconds = 0, fractions = 0, flen1 = 0, flen2 = 0;
+ const char * val = PQgetvalue(sc->execRes, sc->tuple, colNo);
+ if (sscanf(val, "%d days %d:%d:%d.%n%d%n", &days, &hours, &minutes, &seconds, &flen1, &fractions, &flen2) >= 4) {
+ h.interval(boost::posix_time::time_duration((24 * days) + hours, minutes, seconds, fractions * pow(10, boost::posix_time::time_res_traits::num_fractional_digits() + flen1 - flen2)));
+ }
+ else if (sscanf(val, "%d day %d:%d:%d.%n%d%n", &days, &hours, &minutes, &seconds, &flen1, &fractions, &flen2) >= 4) {
+ h.interval(boost::posix_time::time_duration((24 * days) + hours, minutes, seconds, fractions * pow(10, boost::posix_time::time_res_traits::num_fractional_digits() + flen1 - flen2)));
+ }
+ else {
+ h.interval(boost::posix_time::duration_from_string(PQgetvalue(sc->execRes, sc->tuple, colNo)));
+ }
+ break;
+ }
case 702: //ABSTIMEOID:
+ case 1082: //DATEOID:
case 1114: //TIMESTAMPOID:
case 1184: //TIMESTAMPTZOID:
- strptime(PQgetvalue(sc->execRes, sc->tuple, colNo), "%F %T", &tm);
- h.timestamp(tm);
+ h.timestamp(boost::posix_time::time_from_string(PQgetvalue(sc->execRes, sc->tuple, colNo)));
break;
default:
h.string(PQgetvalue(sc->execRes, sc->tuple, colNo), PQgetlength(sc->execRes, sc->tuple, colNo));