CacheSql73 ; Cache Dynamic SQL Query Time: 2010-09-17 14:15:35 #INCLUDE %occExtent #INCLUDE %occInclude #INCLUDE %systemInclude #SQLCOMPILE SELECT=RUNTIME #EXECUTE s %msqlvar="%qsc(%qref" &sql(DECLARE C CURSOR FOR SELECT Main . Intern , Main . Type , Nederlands . Vertaling AS N , Frans . Vertaling AS F , Engels . Vertaling AS E , Duits . Vertaling AS D INTO :%d(%qref,1), :%d(%qref,2), :%d(%qref,3), :%d(%qref,4), :%d(%qref,5), :%d(%qref,6) FROM Res . VertalingAbstract AS Main LEFT JOIN Res . VertalingAbstract AS Nederlands ON Nederlands . Intern = Main . Intern AND Nederlands . Taal = ? AND Main . Type = Nederlands . Type AND Main . Groep = Nederlands . Groep LEFT JOIN Res . VertalingAbstract AS Frans ON Frans . Intern = Main . Intern AND Frans . Taal = ? AND Frans . Type = Frans . Type AND Main . Groep = Frans . Groep LEFT JOIN Res . VertalingAbstract AS Engels ON Engels . Intern = Main . Intern AND Engels . Taal = ? LEFT JOIN Res . VertalingAbstract AS Duits ON Duits . Intern = Main . Intern AND Duits . Taal = ? WHERE Main . Groep = ? AND ( Main . Type = ? OR Main . Type = ? ) GROUP BY Main . Intern) Execute() n %parm,lsParameters,ptr,pVal,pValType,pQMC s lsParameters=$lg(qHandle,3) Quit:($ll(lsParameters)/2)'=7 $$$ERROR($$$InvalidNumberParmValues) s pQMC=0 For ptr=1:1:7 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))_$lb(%d(%qref,5))_$lb(%d(%qref,6)) 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))_$lb(%d(%qref,5))_$lb(%d(%qref,6)),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,1193623276,"CacheSql73",0)) s colinfo=$lg(info,1),parminfo=$lg(info,2),idinfo=$lg(info,3) s:$g(extoption) extinfo=$g(^mcq("Query",7,1193623276,"CacheSql73",1)) Quit $$$OK GetODBCInfo() Set colinfo=$g(^mcq("Query",7,1193623276,"CacheSql73",2)),parminfo="" Quit $$$OK