Logo ROOT  
Reference Guide
TODBCRow.cxx
Go to the documentation of this file.
1// @(#)root/odbc:$Id$
2// Author: Sergey Linev 6/02/2006
3
4/*************************************************************************
5 * Copyright (C) 1995-2006, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12#include "TODBCRow.h"
13
14#include <sqlext.h>
15
16
18
19////////////////////////////////////////////////////////////////////////////////
20/// Single row of query result.
21
22TODBCRow::TODBCRow(SQLHSTMT stmt, Int_t fieldcount)
23{
24 fHstmt = stmt;
25 fFieldCount = fieldcount;
26
27 fBuffer = 0;
28 fLengths = 0;
29
30 if (fFieldCount>0) {
31 fBuffer = new char*[fFieldCount];
33 for (Int_t n = 0; n < fFieldCount; n++) {
34 fBuffer[n] = 0;
35 fLengths[n] = 0;
37 }
38 }
39}
40
41////////////////////////////////////////////////////////////////////////////////
42/// Destroy row object.
43
45{
46 Close();
47}
48
49////////////////////////////////////////////////////////////////////////////////
50/// Close row.
51
53{
54 if (fBuffer!=0) {
55 for (Int_t n = 0; n < fFieldCount; n++)
56 delete[] fBuffer[n];
57 delete[] fBuffer;
58 fBuffer = 0;
59 }
60
61 if (fLengths!=0) {
62 delete[] fLengths;
63 fLengths = 0;
64 }
65}
66
67////////////////////////////////////////////////////////////////////////////////
68/// Extracts field value from statement.
69/// First allocates 128 bytes for buffer.
70/// If there is not enouth space, bigger buffer is allocated and
71/// request is repeated
72
74{
75 #define buffer_len 128
76
77 fBuffer[field] = new char[buffer_len];
78
79 SQLLEN ressize;
80
81 SQLRETURN retcode = SQLGetData(fHstmt, field+1, SQL_C_CHAR, fBuffer[field], buffer_len, &ressize);
82
83 if (ressize==SQL_NULL_DATA) {
84 delete[] fBuffer[field];
85 fBuffer[field] = 0;
86 return;
87 }
88
89 fLengths[field] = ressize;
90
91 if (retcode==SQL_SUCCESS_WITH_INFO) {
92 SQLINTEGER code;
93 SQLCHAR state[ 7 ];
94 SQLGetDiagRec(SQL_HANDLE_STMT, fHstmt, 1, state, &code, 0, 0, 0);
95
96 if (strcmp((char*)state,"01004")==0) {
97// Info("CopyFieldValue","Before %d %s", ressize, fBuffer[field]);
98
99 char* newbuf = new char[ressize+10];
100 strlcpy(newbuf, fBuffer[field], buffer_len);
101 delete fBuffer[field];
102 fBuffer[field] = newbuf;
103 newbuf+=(buffer_len-1); // first data will not be read again
104 retcode = SQLGetData(fHstmt, field+1, SQL_C_CHAR, newbuf, ressize+10-buffer_len, &ressize);
105
106// Info("CopyFieldValue","After %d %s", ressize, fBuffer[field]);
107 }
108 }
109}
110
111////////////////////////////////////////////////////////////////////////////////
112/// Get length in bytes of specified field.
113
115{
116 if ((field<0) || (field>=fFieldCount)) return 0;
117
118 return fLengths[field];
119}
120
121////////////////////////////////////////////////////////////////////////////////
122/// Get specified field from row (0 <= field < GetFieldCount()).
123
124const char *TODBCRow::GetField(Int_t field)
125{
126 if ((field<0) || (field>=fFieldCount)) return 0;
127
128 return fBuffer[field];
129}
unsigned long ULong_t
Definition: RtypesCore.h:53
const char Option_t
Definition: RtypesCore.h:64
#define ClassImp(name)
Definition: Rtypes.h:361
#define buffer_len
TODBCRow(const TODBCRow &)=delete
char ** fBuffer
Definition: TODBCRow.h:33
void Close(Option_t *opt="") final
Close row.
Definition: TODBCRow.cxx:52
const char * GetField(Int_t field) final
Get specified field from row (0 <= field < GetFieldCount()).
Definition: TODBCRow.cxx:124
ULong_t GetFieldLength(Int_t field) final
Get length in bytes of specified field.
Definition: TODBCRow.cxx:114
Int_t fFieldCount
Definition: TODBCRow.h:32
SQLHSTMT fHstmt
Definition: TODBCRow.h:31
ULong_t * fLengths
Definition: TODBCRow.h:34
virtual ~TODBCRow()
Destroy row object.
Definition: TODBCRow.cxx:44
void CopyFieldValue(Int_t field)
Extracts field value from statement.
Definition: TODBCRow.cxx:73
const Int_t n
Definition: legend1.C:16