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



No it means you attempted to put data into a field that is shorter than
the actual data length from the data base. Use SUBSTR() in the query or
make the host field bigger.  This is a warning only, the record was
still passed to your program from the database.  

Thank you,
Matt Tyler
WinCo Foods, LLC
mattt@xxxxxxxxxxxxxx


-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Douglas W. Palme
Sent: Wednesday, October 26, 2005 1:35 PM
To: RPG programming on the AS400 / iSeries
Subject: RE: embedded sql

When I run the query in interactive mode it runs fine and returns the 
correct number of results....however after the fourth record is read in
the 
program it generates an sqlstt code of '01004' which appears to be some
kind 
of sort error.  Here is the code:

C     NOCATEGORY    BEGSR                            
                                                     
C/EXEC SQL                                           
C+    DECLARE NOCAT CURSOR                           
C+    FOR SELECT                                     
C+        ILNSOLDTO,                                 
C+        ICMNAME,                                   
C+        ILNSLSMN,                                  
C+        SUM(ILNEPRICE),                            
C+        SUM(ILNEUAVCST),                           
C+        SUM(ILNEPRICE) - SUM(ILNEUAVCST) AS MARGIN 
C+    FROM CLASSCATLF                                
C+    WHERE                                          
C+        ILNINVDATE >= :DSDATE AND                  
C+        ILNINVDATE <= :DEDATE AND                  
C+        ITMCLASS = :DCLASS                         
 C+    GROUP BY                        
 C+        ILNSLSMN, ILNSOLDTO, ICMNAME
 C+    ORDER BY                        
 C+        ILNSLSMN,                   
 C+        MARGIN DESC                 
 C/END-EXEC                            
                                       
 C/EXEC SQL                            
 C+    OPEN NOCAT                      
C/END-EXEC                                                   
C                   WRITE     HEADINGS                       
C                   DOW       sqlstt = SQLSTATEOK            
C/EXEC SQL                                                   
C+                                                           
C+    FETCH NOCAT                                            
C+    INTO :DCUSTNO, :DNAME, :DSLS, :DSALES, :DCOST, :DMARGIN
C/END-EXEC                                                   
C                   IF        *IN99 = *ON                    
...




On Wed, 26 Oct 2005 10:20:24 -0500, Holden Tommy wrote
> You can check the SQLCOD or the SQLSTT values to determine if the
> statement was successful or not.
> 
> SQLCOD=*zeros = success
> SQLCOD=100 = end of cursor(EOF)
> 
> For SQLSTT values you can find most of them at 
> http://wiki.midrange.com/index.php/SQLSTATE_Constants
> 
> Thanks,
> Tommy Holden
> 
> -----Original Message-----
> From: rpg400-l-bounces@xxxxxxxxxxxx
> [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Douglas W. Palme
> Sent: Wednesday, October 26, 2005 10:09 AM
> To: RPG Group
> Subject: embedded sql
> 
> When using embedded SQL in RPG, I need to know when there are no more
> records to process from the query, I know that I can use a count(*)
> statement but that seems completely inefficient.
> 
> Is there not an SQL variable that I can use to determine that the
SELECT
> INTO statement has no more records to process?
> 
> I checked the embedded SQL programming guide but did not find 
> anything relevant to RPG
> 
> If you bought it, it was hauled by a truck - somewhere, sometime.
> 
> -- 
> This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing
> list
> To post a message email: RPG400-L@xxxxxxxxxxxx
> To subscribe, unsubscribe, or change list options,
> visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
> or email: RPG400-L-request@xxxxxxxxxxxx
> Before posting, please take a moment to review the archives
> at http://archive.midrange.com/rpg400-l.
> 
> -- 
> This is the RPG programming on the AS400 / iSeries (RPG400-L)
>  mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To 
> subscribe, unsubscribe, or change list options, visit: 
> http://lists.midrange.com/mailman/listinfo/rpg400-l or email: RPG400-
> L-request@xxxxxxxxxxxx Before posting, please take a moment to 
> review the archives at http://archive.midrange.com/rpg400-l.


If you bought it, it was hauled by a truck - somewhere, sometime.


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.