CacheSql26 ; Cache Dynamic SQL Query Time: 2005-10-20 16:06:40 #INCLUDE %occExtent #INCLUDE %occInclude #INCLUDE %systemInclude #SQLCOMPILE SELECT=RUNTIME #EXECUTE s %msqlvar="%qsc(%qref" &sql(DECLARE C CURSOR FOR SELECT KlNr , UserWW INTO :%d(%qref,1), :%d(%qref,2) FROM WS_EC . USERS WHERE KlNr = ?) Execute() n %parm,lsParameters,ptr,pVal,pValType,pQMC s lsParameters=$lg(qHandle,3) Quit:($ll(lsParameters)/2)'=1 $$$ERROR($$$InvalidNumberParmValues) s pQMC=0 For ptr=1:1:1 Set pValType=$li(lsParameters,ptr*2-1),pVal=$li(lsParameters,ptr*2),%parm(ptr)=$s(pValType="c":pVal,pValType="v":@pVal,1:pVal) &sql(OPEN C) Quit $s('SQLCODE:$$$OK,1:$$$ERROR($$$QueryCannotInstantiate,"SQLCODE = "_SQLCODE)) Close() &sql(CLOSE C) q:SQLCODE $$$ERROR($$$SQLError,"SQLCODE = "_SQLCODE_" "_$g(%msg)) k %d(%qref),%qscc(%qref),%qscd(%qref),%qscp(%qref),%qscs(%qref),%qsct(%qref),%qscl(%qref),%qscR(%qref),%qscZ(%qref) QUIT $$$OK Fetch() s AtEnd=$g(AtEnd,0) n SQLCODE s Row="",AtEnd=0 &sql(FETCH C) i 'SQLCODE s Row=$lb(%d(%qref,1))_$lb(%d(%qref,2)) i 1 e s AtEnd=1 QUIT $s('SQLCODE:$$$OK,SQLCODE=100:$$$OK,1:$$$ERROR($$$SQLError,"SQLCODE = "_SQLCODE_" "_$g(%msg))) FetchRows() s FetchCount=$g(FetchCount,0) n done,i,SQLCODE s done=0,RowSet="",ReturnCount=0,AtEnd=0 f i=1:1 DO q:done . &sql(FETCH C) . i 'SQLCODE s RowSet=RowSet_$lb(%d(%qref,1))_$lb(%d(%qref,2)),ReturnCount=ReturnCount+1 s:ReturnCount=FetchCount done=1 s:($l(RowSet)+($l(RowSet)\ReturnCount))>24000 done=1 i 1 . e s done=1,AtEnd=1 QUIT $s('SQLCODE:$$$OK,SQLCODE=100:$$$OK,1:$$$ERROR($$$SQLError,"SQLCODE = "_SQLCODE_" "_$g(%msg))) GetInfo() n info,qhparms s info=$g(^mcq("Query",7,3338631355,"CacheSql26",0)) s colinfo=$lg(info,1),parminfo=$lg(info,2),idinfo=$lg(info,3) s:$g(extoption) extinfo=$g(^mcq("Query",7,3338631355,"CacheSql26",1)) Quit $$$OK