CacheSql89 ; Cache Dynamic SQL Query Time: 2010-02-08 15:09:48 #INCLUDE %VHMacro #INCLUDE %occExtent #INCLUDE %occInclude #INCLUDE %systemInclude #SQLCOMPILE SELECT=RUNTIME #EXECUTE s %msqlvar="%qsc(%qref" &sql(DECLARE C CURSOR FOR SELECT BxMain . ItemCode , BxBP1 . TBBoxSide , BxBP2 . element_key , BxBP2 . BeperkGUI INTO :%d(%qref,1), :%d(%qref,2), :%d(%qref,3), :%d(%qref,4) FROM Prod_GAMeta_BT . TBBoxSide AS BxMain , Prod_GAMeta_BT . TBBoxSide_BeperkGUI AS BxBP1 , Prod_GAMeta_BT . TBBoxSide_BeperkGUI AS BxBP2 WHERE ( BxMain . ItemCode = BxBP1 . TBBoxSide ) AND ( BxMain . ItemCode = BxBP2 . TBBoxSide ) AND ( BxBP1 . element_key = ? AND ( ( ? || BxBP1 . BeperkGUI || ? ) LIKE ? OR BxBP1 . BeperkGUI = ? ) ) AND ( BxBP2 . element_key = ? AND ( ( ? || BxBP2 . BeperkGUI || ? ) LIKE ? OR BxBP2 . BeperkGUI = ? ) ) ORDER BY BxBP1 . TBBoxSide -> VolgNr) Execute() n %parm,lsParameters,ptr,pVal,pValType,pQMC s lsParameters=$lg(qHandle,3) Quit:($ll(lsParameters)/2)'=10 $$$ERROR($$$InvalidNumberParmValues) s pQMC=0 For ptr=1:1:10 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))_$lb(%d(%qref,2))_$lb(%d(%qref,3))_$lb(%d(%qref,4)) 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))_$lb(%d(%qref,2))_$lb(%d(%qref,3))_$lb(%d(%qref,4)),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,119664433,"CacheSql89",0)) s colinfo=$lg(info,1),parminfo=$lg(info,2),idinfo=$lg(info,3) s:$g(extoption) extinfo=$g(^mcq("Query",7,119664433,"CacheSql89",1)) Quit $$$OK GetODBCInfo() Set colinfo=$g(^mcq("Query",7,119664433,"CacheSql89",2)),parminfo="" Quit $$$OK