48 m_accessSvc->msg() << MSG::WARNING <<
"RDBQuery cannot be executed more than once! Query: "
64 m_accessSvc->msg() << MSG::ERROR <<
"Cannot connect to the database: "
66 throw std::runtime_error(
"Cannot connect to the database " +
m_connName);
73 for (
char& ch : upperName) {
74 ch = std::toupper (
static_cast<unsigned int>(ch));
84 for(
unsigned int i=0; i<
m_fields.size(); ++i) {
90 const coral::ITableDescription& dataTableDesc =
m_accessSvc->getSession(
m_connName)->nominalSchema().tableHandle(upperName +
"_DATA").description();
91 for(
int i=0; i<dataTableDesc.numberOfColumns(); ++i) {
92 m_query->addToOutputList(upperName+
"_DATA."+dataTableDesc.columnDescription(i).name());
96 m_queryCount->addToOutputList(
"COUNT("+upperName+
"_DATA_ID)",
"SUMREC");
99 m_query->addToTableList(upperName +
"_DATA");
100 m_query->addToTableList(upperName +
"_DATA2TAG");
106 m_query->addToOrderList(upperName +
"_DATA." + upperName +
"_DATA_ID");
114 bindsData.extend<std::string>(
"tagID");
116 std::string queryStructCondition = upperName +
"_DATA2TAG." + upperName +
"_TAG_ID =:tagID";
117 m_queryCount->setCondition(queryStructCondition , bindsData);
119 queryStructCondition +=
" AND " + upperName +
"_DATA." + upperName +
"_DATA_ID=" + upperName +
"_DATA2TAG." + upperName +
"_DATA_ID";
120 m_query->setCondition(queryStructCondition , bindsData);
122 bindsData[0].data<std::string>() =
m_tagId;
125 m_query->setMemoryCacheSize(1);
129 while(cursorCount.next()) {
131 m_size = cursorCount.currentRow()[
"SUMREC"].data<
long>();
138 catch(coral::SchemaException& se) {
139 m_accessSvc->msg() << MSG::WARNING <<
"QUERY: Schema Exception : " + std::string(se.what()) <<
endmsg;
141 catch(std::exception& e) {
142 m_accessSvc->msg() << MSG::WARNING <<
"QUERY: Exception : " + std::string(e.what()) <<
endmsg;