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

📄 deptfactoryi.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 <DeptFactoryI.h>#include <Util.h>#include <sqlca.h>EXEC SQL WHENEVER SQLERROR DO handleSqlError(sqlca, ctx);using namespace std;DeptFactoryI::DeptFactoryI(const CurrentSqlContext& currentCtx, const string& deptCategory, const string& empCategory) :    _currentCtx(currentCtx),    _deptCategory(deptCategory),    _empCategory(empCategory){}HR::DeptPrx DeptFactoryI::createDept(int key, const HR::DeptDesc& desc, const Ice::Current& current){    sqlca sqlca;    EXEC SQL BEGIN DECLARE SECTION;    sql_context ctx = _currentCtx;    int deptno = key;    const char* dname = desc.dname.c_str();    const char* loc = desc.loc.c_str();    EXEC SQL END DECLARE SECTION;        EXEC SQL CONTEXT USE :ctx;    EXEC SQL INSERT INTO DEPT(deptno, dname, loc) VALUES(:deptno, :dname, :loc);     EXEC SQL COMMIT;    Ice::Identity deptId;    deptId.name = encodeName(deptno);    deptId.category = _deptCategory;    return HR::DeptPrx::uncheckedCast(current.adapter->createProxy(deptId));}EXEC SQL WHENEVER NOT FOUND DO break;HR::DeptPrxSeq DeptFactoryI::findAll(const Ice::Current& current){    sqlca sqlca;    EXEC SQL BEGIN DECLARE SECTION;    sql_context ctx = _currentCtx;    int deptno;    EXEC SQL END DECLARE SECTION;    EXEC SQL CONTEXT USE :ctx;    EXEC SQL DECLARE depCursor1 CURSOR FOR SELECT DEPTNO FROM DEPT;    EXEC SQL OPEN depCursor1;           HR::DeptPrxSeq result;    for(;;)    {        EXEC SQL FETCH depCursor1 INTO :deptno;        Ice::Identity deptId;        deptId.category = _deptCategory;        deptId.name = encodeName(deptno);        result.push_back(HR::DeptPrx::uncheckedCast(current.adapter->createProxy(deptId)));    }    EXEC SQL CLOSE depCursor1;    EXEC SQL COMMIT;    return result;}HR::DeptPrxSeq DeptFactoryI::findByName(const string& name, const Ice::Current& current){    sqlca sqlca;    EXEC SQL BEGIN DECLARE SECTION;    const char* dname = name.c_str();    sql_context ctx = _currentCtx;    int deptno;    EXEC SQL END DECLARE SECTION;    EXEC SQL CONTEXT USE :ctx;    EXEC SQL DECLARE depCursor2 CURSOR FOR SELECT DEPTNO FROM DEPT WHERE DNAME = :dname;    EXEC SQL OPEN depCursor2;          HR::DeptPrxSeq result;    for(;;)    {        EXEC SQL FETCH depCursor2 INTO :deptno;        Ice::Identity deptId;        deptId.category = _deptCategory;        deptId.name = encodeName(deptno);        result.push_back(HR::DeptPrx::uncheckedCast(current.adapter->createProxy(deptId)));    }    EXEC SQL CLOSE depCursor2;    EXEC SQL COMMIT;    return result;}HR::DeptPrxDeptFactoryI::findDeptByNo(int deptno, const Ice::Current& current){    Ice::Identity deptId;    deptId.category = _deptCategory;    deptId.name = encodeName(deptno);    Ice::ObjectPrx prx = current.adapter->createProxy(deptId);     //    // Check that this deptno exists    //    try    {        prx->ice_ping();    }    catch(const Ice::ObjectNotExistException&)    {        return 0;    }        return HR::DeptPrx::uncheckedCast(prx);}HR::EmpPrxDeptFactoryI::findEmpByNo(int empno, const Ice::Current& current){    Ice::Identity empId;    empId.category = _empCategory;    empId.name = encodeName(empno);    Ice::ObjectPrx prx = current.adapter->createProxy(empId);    //    // Check that this empno exists    //    try    {        prx->ice_ping();    }    catch(const Ice::ObjectNotExistException&)    {        return 0;    }        return HR::EmpPrx::uncheckedCast(prx);}

⌨️ 快捷键说明

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