CMS 3D CMS Logo

ODVfeToRejectDat.cc
Go to the documentation of this file.
1 #include <stdexcept>
2 #include <string>
4 
6 
7 using namespace std;
8 using namespace oracle::occi;
9 
11  m_env = nullptr;
12  m_conn = nullptr;
13  m_writeStmt = nullptr;
14  m_readStmt = nullptr;
15 
16  m_fed = 0;
17  m_tt = 0;
18  m_vfe = 0;
19  m_gain = 0;
20  m_sta = 0;
21 }
22 
24 
26  this->checkConnection();
27 
28  try {
29  m_writeStmt = m_conn->createStatement();
30  m_writeStmt->setSQL("INSERT INTO " + getTable() +
31  " (rec_id, fed_id, tt_id, vfe_id, GAIN, STATUS ) "
32  "VALUES (:1, :2, :3, :4, :5 , :6 )");
33  } catch (SQLException& e) {
34  throw(std::runtime_error("ODVfeToRejectDat::prepareWrite(): " + e.getMessage()));
35  }
36 }
37 
39  this->checkConnection();
40 
41  try {
42  m_writeStmt->setInt(1, item->getId());
43  m_writeStmt->setInt(2, item->getFedId());
44  m_writeStmt->setInt(3, item->getTTId());
45  m_writeStmt->setInt(4, item->getVfeId());
46  m_writeStmt->setInt(5, item->getGain());
47  m_writeStmt->setInt(6, item->getStatus());
48 
49  m_writeStmt->executeUpdate();
50  } catch (SQLException& e) {
51  throw(std::runtime_error("ODVfeToRejectDat::writeDB(): " + e.getMessage()));
52  }
53 }
54 
55 void ODVfeToRejectDat::fetchData(std::vector<ODVfeToRejectDat>* p, ODVfeToRejectInfo* iov) noexcept(false) {
56  this->checkConnection();
57 
58  iov->setConnection(m_env, m_conn);
59  int iovID = iov->fetchID();
60  if (!iovID) {
61  std::cout << "ID not in the DB" << endl;
62  return;
63  }
64 
65  try {
66  m_readStmt->setSQL("SELECT * FROM " + getTable() + " WHERE rec_id = :rec_id order by fed_id, tt_id, vfe_id ");
67  m_readStmt->setInt(1, iovID);
68  ResultSet* rset = m_readStmt->executeQuery();
69 
70  // std::vector< ODVfeToRejectDat > p;
71  ODVfeToRejectDat dat;
72  while (rset->next()) {
73  // dat.setId( rset->getInt(1) );
74  dat.setFedId(rset->getInt(2));
75  dat.setTTId(rset->getInt(3));
76  dat.setVfeId(rset->getInt(4));
77  dat.setGain(rset->getInt(5));
78  dat.setStatus(rset->getInt(6));
79 
80  p->push_back(dat);
81  }
82 
83  } catch (SQLException& e) {
84  throw(std::runtime_error("ODVfeToRejectDat::fetchData(): " + e.getMessage()));
85  }
86 }
87 
88 // ************************************************************************ //
89 
90 void ODVfeToRejectDat::writeArrayDB(const std::vector<ODVfeToRejectDat>& data, ODVfeToRejectInfo* iov) noexcept(false) {
91  this->checkConnection();
92 
93  int iovID = iov->fetchID();
94  if (!iovID) {
95  throw(std::runtime_error("ODDelays::writeArrayDB: ODFEDelaysInfo not in DB"));
96  }
97 
98  int nrows = data.size();
99  int* ids = new int[nrows];
100  int* xx = new int[nrows];
101  int* yy = new int[nrows];
102  int* zz = new int[nrows];
103  int* ww = new int[nrows];
104  int* st = new int[nrows];
105 
106  ub2* ids_len = new ub2[nrows];
107  ub2* x_len = new ub2[nrows];
108  ub2* y_len = new ub2[nrows];
109  ub2* z_len = new ub2[nrows];
110  ub2* w_len = new ub2[nrows];
111  ub2* st_len = new ub2[nrows];
112 
113  ODVfeToRejectDat dataitem;
114 
115  for (int count = 0; count != (int)data.size(); count++) {
116  dataitem = data[count];
117  ids[count] = iovID;
118  xx[count] = dataitem.getFedId();
119  yy[count] = dataitem.getTTId();
120  zz[count] = dataitem.getVfeId();
121  ww[count] = dataitem.getGain();
122  st[count] = dataitem.getStatus();
123 
124  ids_len[count] = sizeof(ids[count]);
125  x_len[count] = sizeof(xx[count]);
126  y_len[count] = sizeof(yy[count]);
127  z_len[count] = sizeof(zz[count]);
128  w_len[count] = sizeof(ww[count]);
129  st_len[count] = sizeof(st[count]);
130  }
131 
132  try {
133  m_writeStmt->setDataBuffer(1, (dvoid*)ids, OCCIINT, sizeof(ids[0]), ids_len);
134  m_writeStmt->setDataBuffer(2, (dvoid*)xx, OCCIINT, sizeof(xx[0]), x_len);
135  m_writeStmt->setDataBuffer(3, (dvoid*)yy, OCCIINT, sizeof(yy[0]), y_len);
136  m_writeStmt->setDataBuffer(4, (dvoid*)zz, OCCIINT, sizeof(zz[0]), z_len);
137  m_writeStmt->setDataBuffer(5, (dvoid*)ww, OCCIINT, sizeof(ww[0]), w_len);
138  m_writeStmt->setDataBuffer(6, (dvoid*)st, OCCIINT, sizeof(st[0]), st_len);
139 
140  m_writeStmt->executeArrayUpdate(nrows);
141 
142  delete[] ids;
143  delete[] xx;
144  delete[] yy;
145  delete[] zz;
146  delete[] ww;
147  delete[] st;
148 
149  delete[] ids_len;
150  delete[] x_len;
151  delete[] y_len;
152  delete[] z_len;
153  delete[] w_len;
154  delete[] st_len;
155 
156  } catch (SQLException& e) {
157  throw(std::runtime_error("ODVfeToRejectDat::writeArrayDB(): " + e.getMessage()));
158  }
159 }
ODVfeToRejectDat::~ODVfeToRejectDat
~ODVfeToRejectDat() override
Definition: ODVfeToRejectDat.cc:23
ODVfeToRejectInfo
Definition: ODVfeToRejectInfo.h:9
geometryCSVtoXML.zz
zz
Definition: geometryCSVtoXML.py:19
ODVfeToRejectDat::getVfeId
int getVfeId() const
Definition: ODVfeToRejectDat.h:30
funct::false
false
Definition: Factorize.h:29
ODVfeToRejectDat::prepareWrite
void prepareWrite() noexcept(false) override
Definition: ODVfeToRejectDat.cc:25
AlCaHLTBitMon_ParallelJobs.p
p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
gather_cfg.cout
cout
Definition: gather_cfg.py:144
ODVfeToRejectDat::setStatus
void setStatus(int dac)
Definition: ODVfeToRejectDat.h:35
ODVfeToRejectDat::getFedId
int getFedId() const
Definition: ODVfeToRejectDat.h:24
IODConfig::SQLException
oracle::occi::SQLException SQLException
Definition: IODConfig.h:20
ODVfeToRejectDat::writeDB
void writeDB(const ODVfeToRejectDat *item, ODVfeToRejectInfo *iov) noexcept(false)
Definition: ODVfeToRejectDat.cc:38
ODVfeToRejectDat
Definition: ODVfeToRejectDat.h:11
oracle::occi
Definition: ConnectionManager.h:7
submitPVResolutionJobs.count
count
Definition: submitPVResolutionJobs.py:352
ODVfeToRejectDat.h
ODVfeToRejectDat::getTTId
int getTTId() const
Definition: ODVfeToRejectDat.h:27
ODVfeToRejectDat::ODVfeToRejectDat
ODVfeToRejectDat()
Definition: ODVfeToRejectDat.cc:10
geometryCSVtoXML.yy
yy
Definition: geometryCSVtoXML.py:19
ODVfeToRejectDat::writeArrayDB
void writeArrayDB(const std::vector< ODVfeToRejectDat > &data, ODVfeToRejectInfo *iov) noexcept(false)
Definition: ODVfeToRejectDat.cc:90
ODVfeToRejectDat::getStatus
int getStatus() const
Definition: ODVfeToRejectDat.h:36
createfilelist.int
int
Definition: createfilelist.py:10
ODVfeToRejectDat::setFedId
void setFedId(int dac)
Definition: ODVfeToRejectDat.h:23
ODVfeToRejectDat::setVfeId
void setVfeId(int dac)
Definition: ODVfeToRejectDat.h:29
ODVfeToRejectDat::fetchData
void fetchData(std::vector< ODVfeToRejectDat > *fillMap, ODVfeToRejectInfo *iov) noexcept(false)
Definition: ODVfeToRejectDat.cc:55
B2GTnPMonitor_cfi.item
item
Definition: B2GTnPMonitor_cfi.py:147
ODVfeToRejectDat::setTTId
void setTTId(int dac)
Definition: ODVfeToRejectDat.h:26
std
Definition: JetResolutionObject.h:76
ODVfeToRejectDat::getGain
int getGain() const
Definition: ODVfeToRejectDat.h:33
data
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:79
Oracle.h
geometryCSVtoXML.xx
xx
Definition: geometryCSVtoXML.py:19
ODVfeToRejectDat::setGain
void setGain(int dac)
Definition: ODVfeToRejectDat.h:32
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37