CacheSql100 ; Cache Dynamic SQL Query Time: 2010-02-08 15:14:56 #INCLUDE %VHMacro #INCLUDE %occExtent #INCLUDE %occInclude #INCLUDE %systemInclude #SQLCOMPILE SELECT=RUNTIME #EXECUTE s %msqlvar="%qsc(%qref" &sql(DECLARE C CURSOR FOR SELECT BxMain . ItemCode INTO :%d(%qref,1) FROM Prod_GAMeta_BT . TBBoxSide AS BxMain , Prod_GAMeta_BT . TBBoxSide_BeperkGUI AS BxBP1 WHERE ( BxMain . ItemCode = BxBP1 . TBBoxSide ) AND ( BxBP1 . element_key = ? AND ( ( ? || BxBP1 . BeperkGUI || ? ) LIKE ? OR BxBP1 . BeperkGUI = ? ) ) ORDER BY BxMain . VolgNr) Execute() n %parm,lsParameters,ptr,pVal,pValType,pQMC s lsParameters=$lg(qHandle,3) Quit:($ll(lsParameters)/2)'=5 $$$ERROR($$$InvalidNumberParmValues) s pQMC=0 For ptr=1:1:5 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) If 'SQLCODE { Set sc=$$$OK } Else { Set:$isobject($g(%sqlcontext)) %sqlcontext.SQLCode=SQLCODE,%sqlcontext.Message=$g(%msg) Set sc=$$$ERROR($$$QueryCannotInstantiate,"SQLCODE = "_SQLCODE) } Quit sc Close() &sql(CLOSE C) q:SQLCODE $$$ERROR($$$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,sc s Row="",AtEnd=0 &sql(FETCH C) i 'SQLCODE s Row=$lb(%d(%qref,1)) i 1 e s AtEnd=1 QUIT $s('SQLCODE:$$$OK,SQLCODE=100:$$$OK,1:$$$ERROR($$$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)),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($$$SQLCode,SQLCODE,$g(%msg))) GetInfo() n info,qhparms s info=$g(^mcq("Query",7,268948458,"CacheSql100",0)) s colinfo=$lg(info,1),parminfo=$lg(info,2),idinfo=$lg(info,3) s:$g(extoption) extinfo=$g(^mcq("Query",7,268948458,"CacheSql100",1)) Quit $$$OK GetODBCInfo() Set colinfo=$g(^mcq("Query",7,268948458,"CacheSql100",2)),parminfo="" Quit $$$OK