⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 currentsqlcontext.pc

📁 ICE-3.2 一个开源的中间件
💻 PC
字号:
// **********************************************************************//// Copyright (c) 2003-2006 ZeroC, Inc. All rights reserved.//// This copy of Ice is licensed to you under the terms described in the// ICE_LICENSE file included in this distribution.//// **********************************************************************#include <Ice/Ice.h>#include <CurrentSqlContext.h>#include <sqlca.h>#include <Util.h>using namespace std;#ifndef TRACE// #   define TRACE 1#endif#ifdef _MSC_VER   #define __thread __declspec(thread)#endifnamespace{//// Each CurrentSqlContext object gets its own slot (index) in the vector// (and there is a separate vector in each thread)//__thread std::vector<sql_context>* _current = 0;size_t _currentIndex = 0;class Notification : public Ice::ThreadNotification{public:        Notification(size_t index) :        _index(index)    {    }    virtual void start()    {    }    virtual void stop()    {        if(_current != 0 && _index < _current->size())        {#ifdef TRACE            cerr << "Disconnecting from Oracle in thread " << IceUtil::ThreadControl().id() << endl;#endif            EXEC SQL BEGIN DECLARE SECTION;            sql_context ctx = (*_current)[_index];            EXEC SQL END DECLARE SECTION;                        if(ctx != 0)            {                (*_current)[_index] = 0;                EXEC SQL CONTEXT USE :ctx;                sqlca sqlca;                EXEC SQL ROLLBACK RELEASE;                EXEC SQL CONTEXT FREE :ctx;            }            if(find_if(_current->begin(), _current->end(), bind2nd(not_equal_to<sql_context>(), static_cast<void*>(0)))               == _current->end())            {#ifdef TRACE                cerr << "Deleting _current in thread " << IceUtil::ThreadControl().id() << endl;#endif                delete _current;                _current = 0;            }        }    }private:    const size_t _index;};}CurrentSqlContext::CurrentSqlContext(const string& connectInfo) :    _connectInfo(connectInfo){    {        IceUtil::StaticMutex::Lock lock(IceUtil::globalMutex);        _index = _currentIndex++;    }    _hook = new Notification(_index);}Ice::ThreadNotificationPtrCurrentSqlContext::getHook() const{     return _hook;}CurrentSqlContext::operator sql_context() const{    if(_current == 0)    {        _current = new std::vector<sql_context>(_index + 1);    }    if(_index >= _current->size())    {        _current->resize(_index + 1);    }    EXEC SQL BEGIN DECLARE SECTION;    sql_context ctx = (*_current)[_index];    const char* connectInfo = _connectInfo.c_str();    EXEC SQL END DECLARE SECTION;        EXEC SQL WHENEVER SQLERROR DO handleSqlError(sqlca, ctx);    if(ctx == 0)    {#ifdef TRACE        cerr << "Connecting to Oracle in thread " << IceUtil::ThreadControl().id() << endl;#endif        //        // Allocate and connect        //        sqlca sqlca;                EXEC SQL CONTEXT ALLOCATE :ctx;        EXEC SQL CONTEXT USE :ctx;        EXEC SQL CONNECT :connectInfo;        (*_current)[_index] = ctx;    }    return ctx;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -