CMS 3D CMS Logo

ODPedestalOffsetsDat.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_sm = 0;
17  m_fed = 0;
18  m_tt = 0;
19  m_xt = 0;
20  m_low = 0;
21  m_mid = 0;
22  m_high = 0;
23 }
24 
26 
28  this->checkConnection();
29 
30  try {
31  m_writeStmt = m_conn->createStatement();
32  m_writeStmt->setSQL("INSERT INTO " + getTable() +
33  " (rec_id, sm_id, fed_id, tt_id, cry_id, low, mid, high) "
34  "VALUES (:1, :2, :3, :4, :5, :6, :7, :8 )");
35  } catch (SQLException& e) {
36  throw(std::runtime_error("ODPedestalOffsetsDat::prepareWrite(): " + e.getMessage()));
37  }
38 }
39 
41  this->checkConnection();
42 
43  try {
44  m_writeStmt->setInt(1, item->getId());
45  m_writeStmt->setInt(2, item->getSMId());
46  m_writeStmt->setInt(3, item->getFedId());
47  m_writeStmt->setInt(4, item->getTTId());
48  m_writeStmt->setInt(5, item->getCrystalId());
49  m_writeStmt->setInt(6, item->getLow());
50  m_writeStmt->setInt(7, item->getMid());
51  m_writeStmt->setInt(8, item->getHigh());
52 
53  m_writeStmt->executeUpdate();
54  } catch (SQLException& e) {
55  throw(std::runtime_error("ODPedestalOffsetsDat::writeDB(): " + e.getMessage()));
56  }
57 }
58 
59 void ODPedestalOffsetsDat::fetchData(std::vector<ODPedestalOffsetsDat>* p,
60  ODFEPedestalOffsetInfo* iov) noexcept(false) {
61  this->checkConnection();
62 
63  iov->setConnection(m_env, m_conn);
64  int iovID = iov->fetchID();
65  if (!iovID) {
66  std::cout << "ID not in the DB" << endl;
67  return;
68  }
69 
70  try {
71  m_readStmt->setSQL("SELECT * FROM " + getTable() + " WHERE rec_id = :rec_id order by sm_id, fed_id, tt_id, cry_id");
72  m_readStmt->setInt(1, iovID);
73  ResultSet* rset = m_readStmt->executeQuery();
74 
75  // std::vector< ODPedestalOffsetsDat > p;
77  while (rset->next()) {
78  // dat.setId( rset->getInt(1) );
79  dat.setSMId(rset->getInt(2));
80  dat.setFedId(rset->getInt(3));
81  dat.setTTId(rset->getInt(4));
82  dat.setCrystalId(rset->getInt(5));
83  dat.setLow(rset->getInt(6));
84  dat.setMid(rset->getInt(7));
85  dat.setHigh(rset->getInt(8));
86 
87  p->push_back(dat);
88  }
89 
90  } catch (SQLException& e) {
91  throw(std::runtime_error("ODPedestalOffsetsDat::fetchData(): " + e.getMessage()));
92  }
93 }
94 
95 // ************************************************************************ //
96 
97 void ODPedestalOffsetsDat::writeArrayDB(const std::vector<ODPedestalOffsetsDat>& data,
98  ODFEPedestalOffsetInfo* iov) noexcept(false) {
99  this->checkConnection();
100 
101  int iovID = iov->fetchID();
102  if (!iovID) {
103  throw(std::runtime_error("ODDelays::writeArrayDB: ODFEDelaysInfo not in DB"));
104  }
105 
106  int nrows = data.size();
107  int* ids = new int[nrows];
108  int* xx = new int[nrows];
109  int* yy = new int[nrows];
110  int* zz = new int[nrows];
111  int* st = new int[nrows];
112  int* xx1 = new int[nrows];
113  int* yy1 = new int[nrows];
114  int* zz1 = new int[nrows];
115 
116  ub2* ids_len = new ub2[nrows];
117  ub2* x_len = new ub2[nrows];
118  ub2* y_len = new ub2[nrows];
119  ub2* z_len = new ub2[nrows];
120  ub2* st_len = new ub2[nrows];
121  ub2* x1_len = new ub2[nrows];
122  ub2* y1_len = new ub2[nrows];
123  ub2* z1_len = new ub2[nrows];
124 
125  ODPedestalOffsetsDat dataitem;
126 
127  int n_data = (int)data.size();
128  for (int count = 0; count < n_data; count++) {
129  dataitem = data[count];
130  ids[count] = iovID;
131  xx[count] = dataitem.getSMId();
132  yy[count] = dataitem.getFedId();
133  zz[count] = dataitem.getTTId();
134  st[count] = dataitem.getCrystalId();
135  xx1[count] = dataitem.getLow();
136  yy1[count] = dataitem.getMid();
137  zz1[count] = dataitem.getHigh();
138 
139  ids_len[count] = sizeof(ids[count]);
140  x_len[count] = sizeof(xx[count]);
141  y_len[count] = sizeof(yy[count]);
142  z_len[count] = sizeof(zz[count]);
143  st_len[count] = sizeof(st[count]);
144  x1_len[count] = sizeof(xx1[count]);
145  y1_len[count] = sizeof(yy1[count]);
146  z1_len[count] = sizeof(zz1[count]);
147  }
148 
149  try {
150  m_writeStmt->setDataBuffer(1, (dvoid*)ids, OCCIINT, sizeof(ids[0]), ids_len);
151  m_writeStmt->setDataBuffer(2, (dvoid*)xx, OCCIINT, sizeof(xx[0]), x_len);
152  m_writeStmt->setDataBuffer(3, (dvoid*)yy, OCCIINT, sizeof(yy[0]), y_len);
153  m_writeStmt->setDataBuffer(4, (dvoid*)zz, OCCIINT, sizeof(zz[0]), z_len);
154  m_writeStmt->setDataBuffer(5, (dvoid*)st, OCCIINT, sizeof(st[0]), st_len);
155  m_writeStmt->setDataBuffer(6, (dvoid*)xx1, OCCIINT, sizeof(xx1[0]), x1_len);
156  m_writeStmt->setDataBuffer(7, (dvoid*)yy1, OCCIINT, sizeof(yy1[0]), y1_len);
157  m_writeStmt->setDataBuffer(8, (dvoid*)zz1, OCCIINT, sizeof(zz1[0]), z1_len);
158 
159  m_writeStmt->executeArrayUpdate(nrows);
160 
161  delete[] ids;
162  delete[] xx;
163  delete[] yy;
164  delete[] zz;
165  delete[] st;
166  delete[] xx1;
167  delete[] yy1;
168  delete[] zz1;
169 
170  delete[] ids_len;
171  delete[] x_len;
172  delete[] y_len;
173  delete[] z_len;
174  delete[] st_len;
175  delete[] x1_len;
176  delete[] y1_len;
177  delete[] z1_len;
178 
179  } catch (SQLException& e) {
180  throw(std::runtime_error("ODPedestalOffsetsDat::writeArrayDB(): " + e.getMessage()));
181  }
182 }
void writeArrayDB(const std::vector< ODPedestalOffsetsDat > &data, ODFEPedestalOffsetInfo *iov) noexcept(false)
void writeDB(const ODPedestalOffsetsDat *item, ODFEPedestalOffsetInfo *iov) noexcept(false)
void fetchData(std::vector< ODPedestalOffsetsDat > *fillMap, ODFEPedestalOffsetInfo *iov) noexcept(false)
void prepareWrite() noexcept(false) override
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:79
oracle::occi::SQLException SQLException
Definition: IODConfig.h:20