summaryrefslogtreecommitdiff
path: root/libodbcpp/odbc-column.cpp
blob: 20c68f08abe1efda008b7e5405a341ade9e0fdac (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <sqlext.h>
#include <stdio.h>
#include <stdlib.h>
#include "odbc-column.h"
#include "odbc-command.h"
#include "odbc-selectcommand.h"
#include "odbc-error.h"

ODBC::Column::Column(SelectCommand * sc, const Glib::ustring & s, unsigned int i) :
	DB::Column(s, i),
	selectCmd(sc)
{
	bindLen = 0;
}

ODBC::Column::~Column()
{
}

bool
ODBC::Column::resize()
{
	return false;
}

bool
ODBC::CharArrayColumn::resize()
{
	if (bindLen >= SQLLEN(data.size())) {
		data.resize(bindLen + 1);
		Column::bind();
		if (paramCmd) {
			paramBound = false;
			Param::bind();
		}
		return true;
	}
	return false;
}

bool
ODBC::Column::isNull() const
{
	return (bindLen == SQL_NULL_DATA);
}

void
ODBC::Column::rebind(DB::Command * cmd, unsigned int idx) const
{
	meAsAParam()->paramCmd = dynamic_cast<ODBC::Command *>(cmd);
	meAsAParam()->paramIdx = idx;
	meAsAParam()->bind();
}

void
ODBC::Column::bind()
{
	RETCODE rc = SQLBindCol(selectCmd->hStmt, colNo + 1, ctype(), rwDataAddress(), size(), &bindLen);
	if (!SQL_SUCCEEDED(rc)) {
		throw Error(rc, SQL_HANDLE_STMT, selectCmd->hStmt, "ODBC::Column::bind");
	}
}

ODBC::TimeStampColumn::operator boost::posix_time::ptime() const
{
	return boost::posix_time::ptime(
						boost::gregorian::date(data.year, data.month, data.day),
						boost::posix_time::time_duration(data.hour, data.minute, data.second, data.fraction));
}
ODBC::IntervalColumn::operator boost::posix_time::time_duration() const
{
	auto dur = boost::posix_time::time_duration(
			(24 * data.intval.day_second.day) + data.intval.day_second.hour,
			data.intval.day_second.minute, data.intval.day_second.second, data.intval.day_second.fraction);
	return (data.interval_sign ? -dur : dur);
}
void
ODBC::SignedIntegerColumn::apply(DB::HandleField & h) const
{
	if (isNull()) return h.null();
	h.integer(data);
}
void
ODBC::FloatingPointColumn::apply(DB::HandleField & h) const
{
	if (isNull()) return h.null();
	h.floatingpoint(data);
}
void
ODBC::CharArrayColumn::apply(DB::HandleField & h) const
{
	if (isNull()) return h.null();
	h.string(&data.front(), bindLen);
}
void
ODBC::TimeStampColumn::apply(DB::HandleField & h) const
{
	if (isNull()) return h.null();
	h.timestamp(*this);
}
void
ODBC::IntervalColumn::apply(DB::HandleField & h) const
{
	if (isNull()) return h.null();
	h.interval(*this);
}