× 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.


  • Subject: Dynamic SQL Cursor Problem
  • From: "Wills, Mike N. (TC)" <MNWills@xxxxxxxxxxxxxx>
  • Date: Thu, 14 Jun 2001 17:31:06 -0500

I am getting into the wonderful world of SQL. I know how to set up a normal
cursor and process it, but I thought I would use a dynamic SQL statement so
I don't have to deal with 2 cursors that are a bit different, but mostly the
same. However I am having problems. When I run the prepare statement, I get
an SQLCOD error of -312. Which means, "Host variable &1 not defined or not
usable."  What am I doing wrong? 

Here is the relevant code:

 * Dynamic SQL Statements                                               
D VendorSel       S            256            
                                
 * Build the Vendor Cursor                                              
C/EXEC SQL                                                              
C+ DECLARE C1 CURSOR FOR S1                                             
C/END-EXEC                                                              
                                                        
**** Other code including the fetches from the cursors 


C     *INZSR        BegSR                                    
 *                                                                  
C                   EXSR      $BuildSQL                             
 *                                                                  
 * Prepare the Vendor Cursor                                        
C/EXEC SQL                                                          
C+ PREPARE S1 FROM :VendorSel           <<<<< SQLCOD = -312 Here after it
executes                            
C/END-EXEC                                                          
 * Open the Vendor Cursor                                           
C/EXEC SQL                                                          
C+ OPEN C1                                                          
C/END-EXEC                                                          
 *                                                                  
C                   EndSR                                           


C     $BuildSQL     BegSR

 *

 *    Build the SQL statement for the VendorFile Cursor

C                   Eval      VendorSel = 'SELECT * FROM FILENAME'  
 *                                                                 
C                   If        Vendor <> *Blanks                    
C                   Eval      VendorSel = %TRIM(VendorSel) +       
C                             ' WHERE VENDOR = :Vendor'        
C                   EndIf                                          
 *                                                                 
C                   Eval      VendorSel = %TRIM(VendorSel) +       
C                             ' ORDER BY VENDOR'

 *

C                   EndSR

'Vendor' is defined in the 'D' specs, it is inputed with several other
variables. The SQL statement that is built is correct, I can use it as a
static SQL statement. 

Any help would be appreciated...

Mike Wills
+---
| This is the RPG/400 Mailing List!
| To submit a new message, send your mail to RPG400-L@midrange.com.
| To subscribe to this list send email to RPG400-L-SUB@midrange.com.
| To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---

As an Amazon Associate we earn from qualifying purchases.

This thread ...


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

This mailing list archive is Copyright 1997-2024 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.