20using namespace oracle::occi;
69 Error(
"IsValid",
"row closed");
73 Error(
"IsValid",
"field index out of bounds");
87 MetaData fieldMD = (*fFieldInfo)[field];
89 return fieldMD.getInt(MetaData::ATTR_DATA_SIZE);
97 Error(
"TOracleRow",
"GetField(): out-of-range or No RowData/ResultSet/MetaData");
116 char str_number[200];
118 int fPrecision, fScale, fDataType;
124 if (
fResult->isNull(field+1))
continue;
126 fDataType = (*fFieldInfo)[field].getInt(MetaData::ATTR_DATA_TYPE);
130 fPrecision = (*fFieldInfo)[field].getInt(MetaData::ATTR_PRECISION);
131 fScale = (*fFieldInfo)[field].getInt(MetaData::ATTR_SCALE);
133 if ((fScale == 0) || (fPrecision == 0)) {
134 res =
fResult->getString(field+1);
136 double_val =
fResult->getDouble(field+1);
146 res =
fResult->getString(field+1);
152 case SQLT_TIMESTAMP_TZ:
153 case SQLT_TIMESTAMP_LTZ:
158 res =
fResult->getString(field+1);
161 Error(
"GetRowData",
"Oracle type %d was not yet tested - please inform ROOT developers", fDataType);
165 int len = res.length();
172 }
catch (SQLException &oraex) {
173 Error(
"GetRowData",
"%s", (oraex.getMessage()).c_str());
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
~TOracleRow()
Destroy row object.
ULong_t GetFieldLength(Int_t field) final
Get length in bytes of specified field.
Bool_t IsValid(Int_t field)
Check if row is open and field index within range.
TOracleRow(const TOracleRow &)=delete
std::vector< oracle::occi::MetaData > * fFieldInfo
void Close(Option_t *opt="") final
Close row.
oracle::occi::ResultSet * fResult
const char * GetField(Int_t field) final
static const char * GetDatimeFormat()
return value of actul convertion format from timestamps or date to string
static const char * GetFloatFormat()
return current printf format for float/double members, default "%e"