// ********************************************************************** // // 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 #include #include EXEC SQL WHENEVER SQLERROR DO handleSqlError(sqlca, ctx); using namespace std; DeptFactoryI::DeptFactoryI(const CurrentSqlContext& currentCtx, const string& deptCategory) : _currentCtx(currentCtx), _deptCategory(deptCategory) { } HR::DeptPrx DeptFactoryI::createDept(int key, const HR::DeptDesc& desc, const Ice::Current& current) { struct 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)); } HR::DeptPrxSeq DeptFactoryI::findAll(const Ice::Current& current) { struct 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; EXEC SQL WHENEVER NOT FOUND DO BREAK; 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) { struct 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; EXEC SQL WHENEVER NOT FOUND DO BREAK; 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; }