× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



This message is in MIME format. Since your mail reader does not understand
this format, some or all of this message may not be legible.
--
[ Picked text/plain from multipart/alternative ]

Were running r4.5 with just latest cumulative tape..

But for somereason, I can't get a dynamic sql statement to work, it just
seems to hang on the fetch command...

It's a simple Join, with one field, and the where clause is looking for a
match using an item code on table a , and a department code on table B.

This works fine from the command link, and also as a declared statement with
the fields hardcoded..

This is the declared version that did work...

c*exec sql
c* declare  c1 cursor for
c*      select *
c*
c*      from (prdjrnusg a join jpldcusgsm b on
c*              a.pjstr# = b.jpstr#)
c*
c*      where (a.pjhdat between 37110 and 37115) and
c*      a.pjprod in ('1804','1310','2153') and
c*      b.rddid = 'LAB'
c*end-exec

And this is the one that doesn't... I took out all the variables, to test
this...

And it's very likely (probable) that the reason it's not working, is because
I might have a coding error, so I'm including most of the relavant parts..

Dprdjrnusg      E DS                  extname(PRDJRNUSG) inz
d                                     prefix(a_)
Djpldcusgsm     E DS                  extname(jpldcusgsm)  inz
d                                     prefix(b_)

d sql             s           1000    varying

c/exec sql
c+ declare  c1 cursor for DynSqlStmt
c/end-exec

c                  eval      sql=
c                            'Select * ' +
c                            'From (prdjrnusg  a  JOIN '+
c                                  'jpldcusgsm b  '+
c                                  'ON a.pjstr# = b.jpstr#) '+
c                            'WHERE (a.pjhdat between 37110'+
c                            ' AND 37115) ' +
c                            'and a.pjprod in '  +
c                            '(''1804'',''1310'',''2153'')' +
c                            ' and b.rddid = ''LAB'' '
c/exec sql
c+ Prepare DynSqlStmt from :sql
c/end-exec

c/EXEC SQL   OPEN C1
c/end-exec

c                   dou       Done
c/EXEC SQL
c+ FETCH next from c1 INTO :prdjrnusg, :jpldcusgsm
c/END-EXEC

c                   if        sqlcod <> 0
c                   leave
c                   endif



Below was the orginal non hardcoded version...
c*                  eval      sql=
c*                            'Select * ' +
c*                            'From (PrdJrnUsg  a  JOIN '+
c*                                  'JPLDCusgsm b  '+
c*                                  'ON a.pjstr# = b.jpstr#) '+

c*                            'WHERE (a.pjhdat between '+
c*                                       %editc(startdateh:'Z') +
c*                            ' AND ' +
c*                                    %editc(EndDateH:'Z') + ') '+

c*                  if        %trim(dspwhere) <> *blanks
c*                  eval      sql = sql + 'AND '+%trim(dspwhere)
c*                  endif

Thanks, tim


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.