7 namespace persistency {
10 m_session( &session ){
14 m_session( rhs.m_session ){
40 m_transaction( *m_session ){
44 m_session( sessionImpl ),
45 m_transaction( *m_session ){
49 m_session( rhs.m_session ),
50 m_transaction( rhs.m_transaction ){
73 return m_session->transaction->iovDbExists;
84 proxy.
load( tag, full );
89 const boost::posix_time::ptime& snapshottime,
93 proxy.
load( tag, snapshottime, full );
99 return m_session->iovSchema().tagTable().select( tag );
111 if(
m_session->iovSchema().tagTable().select( tag ) )
112 throwException(
"The specified tag \""+tag+
"\" already exist in the database.",
"Session::createIov");
121 const boost::posix_time::ptime& creationTime ){
123 if(
m_session->iovSchema().tagTable().select( tag ) )
124 throwException(
"The specified tag \""+tag+
"\" already exist in the database.",
"Session::createIov");
132 if(
m_session->iovSchema().tagTable().select( tag ) )
133 throwException(
"The specified tag \""+tag+
"\" already exist in the database.",
"Session::createIovForPayload");
135 if( !
m_session->iovSchema().payloadTable().getType( payloadHash, payloadType ) )
136 throwException(
"The specified payloadId \""+payloadHash+
"\" does not exist in the database.",
"Session::createIovForPayload");
150 m_session->iovSchema().iovTable().erase( tag );
155 return m_session->gtSchema().gtTable().select( name );
160 if(
m_session->gtSchema().gtTable().select( name ) )
161 throwException(
"The specified Global Tag \""+name+
"\" already exist in the database.",
"Session::createGlobalTag");
183 proxy.
load( name, preFix, postFix );
188 const std::pair<Binary,Binary>& payloadAndStreamerInfoData,
189 const boost::posix_time::ptime& creationTime ){
191 return m_session->iovSchema().payloadTable().insertIfNew( payloadObjectType, payloadAndStreamerInfoData.first,
192 payloadAndStreamerInfoData.second, creationTime );
200 return m_session->iovSchema().payloadTable().select( payloadHash, payloadType, payloadData, streamerInfoData );
217 m_transaction(transaction),m_status(
true){
GTEditor editGlobalTag(const std::string &name)
Transaction(SessionImpl &session)
bool existsGlobalTag(const std::string &name)
void clearIov(const std::string &tag)
void load(const std::string &tag, bool full=false)
void start(bool readOnly=true)
IOVEditor createIov(const std::string &tag, cond::TimeType timeType, cond::SynchronizationType synchronizationType=cond::SYNCH_ANY)
void load(const std::string &tag)
Transaction & m_transaction
TransactionScope(Transaction &transaction)
Transaction & transaction()
IOVProxy readIov(const std::string &tag, bool full=false)
Transaction & operator=(const Transaction &rhs)
void load(const std::string >Name, const std::string &preFix="", const std::string &postFix="")
coral::ISchema & nominalSchema()
void start(bool readOnly=true)
bool fetchPayloadData(const cond::Hash &payloadHash, std::string &payloadType, cond::Binary &payloadData, cond::Binary &streamerInfoData)
std::string connectionString()
cond::Hash storePayloadData(const std::string &payloadObjectType, const std::pair< Binary, Binary > &payloadAndStreamerInfoData, const boost::posix_time::ptime &creationTime)
IOVEditor editIov(const std::string &tag)
void startTransaction(bool readOnly=true)
bool existsIov(const std::string &tag)
coral::ISessionProxy & coralSession()
bool isTransactionActive(bool deep=true) const
IOVEditor createIovForPayload(const Hash &payloadHash, const std::string &tag, cond::TimeType timeType, cond::SynchronizationType synchronizationType=cond::SYNCH_ANY)
GTEditor createGlobalTag(const std::string &name)
void rollbackTransaction()
Session & operator=(const Session &rhs)
GTProxy readGlobalTag(const std::string &name)
void load(const std::string >Name)
Transaction m_transaction
void throwException(const std::string &message, const std::string &methodName)
std::shared_ptr< SessionImpl > m_session