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



Finally able to devote a little more time to this.  I got the extra
parameters in the RPG service program like you suggested.  Tried using it in
interactive SQL, however I am getting a MCH3601 (Pointer not set for
location referenced) error at the point where I assign a zero value to the
parameter which is the result null indicator.

FWIW:

CREATE FUNCTION dandev/TRUEDATE
 (DEC(2,0), DEC(2,0), DEC(2,0), DEC(2,0))
RETURNS DATE
EXTERNAL NAME 'DANDEV/TRUEDATE(TRUEDATE)'
LANGUAGE RPGLE
NO SQL
NOT DETERMINISTIC
NOT FENCED
RETURNS NULL ON NULL INPUT
PARAMETER STYLE GENERAL WITH NULLS

RPG service program:

    d/copy testsrc,TrueDatePr

    p TrueDate        b                   export

    d TrueDate        pi              d
    d  p_CenturyIn                   2p 0
    d  p_YearIn                      2p 0
    d  p_MonthIn                     2p 0
    d  p_DayIn                       2p 0
    d  pni_CenturyIn                 5i 0
    d  pni_YearIn                    5i 0
    d  pni_MonthIn                   5i 0
    d  pni_DayIn                     5i 0
    d  pni_Result                    5i 0

    d                 ds
    d DateIn                         8s 0
    d  inCentury                     2s 0 Overlay( DateIn : 1 )
    d  inYear                        2s 0 Overlay( DateIn : 3 )
    d  inMonth                       2s 0 Overlay( DateIn : 5 )
    d  inDay                         2s 0 Overlay( DateIn : 7 )

    d DateOut         s               d   Inz

     /free
      inCentury = p_CenturyIn ;
      inYear    = p_YearIn    ;
      inMonth   = p_MonthIn   ;
      inDay     = p_DayIn     ;
      Test(DE) *iso DateIn ;
      If %error ;
        pni_Result = -1 ;   // Null Indicator is set ON
      Else ;
        DateOut = %date( DateIn : *iso ) ;
        pni_Result = 0 ;   // Null Indicator is set OFF
      Endif ;

      *inLR = *off ;
      Return DateOut ;
     /end-free
    p                 e

Any ideas on how to resolve this would be appreciated!

And, since I'm out of here in a few minutes, I will wish all of you a Merry
Christmas!

- Dan

On 12/20/06, Vernon Hamberg <vhamberg@xxxxxxxxxxx> wrote:

Dan -

It is easier than it looks at first - you have it partly figured out.

The parameters used in a SELECT statement are just those that you
define in the CREATE FUNCTION statement. So in the example you would
use 2 CHAR(3) columns (or expression) and a date column (or
expression). And the result has to be put into a numeric column if
used in an UPDATE, say.

But your RPG has to have more parameters than those 3. And it has to
have a return value. The RPG service program would have, in this
case, a prototype with 2 3-character parameters and a date parameter,
followed by - what I do - 3 integers (5 & 0 I think - 2 byte signed)
for the null indicators of the parameters, and a 4th integer for the
null indicator of the return value.

So you would have, in this case, 7 parameters in the RPG function
prototype. To return a NULL, simply set the last parameter to -1 ---
the SQL engine will convert that to what it needs.

Here is a possible prototype - you can use separate parameters for
the indicator "array" - I like it because I can use meaningful names.

DYOURPROC         PR            10P 5
D ORIG_CCY                       3A
D TRGT_CCY                       3A
D FX_DATE                         D
D NIORIG_CCY                     5I 0
D NITRGT_CCY                     5I 0
D NIFX_DATE                      5I 0
D NIRETURNVAL                    5I 0

***NOTE*** I strongly recommend using VARCHAR instead of CHAR for all
character parameters - even single-character ones. This lets you use
simple character literals in the call of the function - otherwise you
have to cast the values to CHAR or use non-varying CHAR columns. If
you do create this function with VARCHARs, then the first 2
parameters would have the VARYING keyword.

Basically it just works. Now if you want to be more SQL-ish, you can
try the SQL style. This lets you return an SQL state value and a
short message text - not much more difficult, actually.

In a SELECT WHERE clause you could say WHERE yourproc('aaa', 'bbb',
current date) is not null

Section 15.3 of the redbook explains this pretty well - i think -
after i studied it a while!!!

HTH
Vern

At 02:54 PM 12/19/2006, you wrote:

>On 12/18/06, Vernon Hamberg <vhamberg@xxxxxxxxxxx> wrote:
> >
> > Dan - you are now in the world of using the SQL or the GENERAL WITH
> > NULLS parameter style - that means you have to add indicators for
> > NULL. This means you cannot use an existing service program as is.
> > Check the redbook for what the parameters need to be. Basically you
> > set an extra parameter to indicate a NULL.
>
>
>Thanks Vern.  I scanned through the redbook.  Sorry, but this is over my
>head, as in, the space shuttle is over my head.  ;-)  I found the
PARAMETER
>STYLE GENERAL WITH NULLS, but...   The example shows:
>
>     CREATE FUNCTION SAMPLEDB01.GET_FX_RATE (
>           ORIG_CCY CHAR(3) ,
>           TRGT_CCY CHAR(3) ,
>           FX_DATE DATE )
>     RETURNS DECIMAL(10, 5)
>     LANGUAGE COBOLLE
>     SPECIFIC SAMPLEDB01.GET_FX_RATE01
>     DETERMINISTIC
>     READS SQL DATA
>     RETURNS NULL ON NULL INPUT
>     EXTERNAL NAME 'SAMPLEDB01/UDF_CBL(GET_FX_RATE)'
>     PARAMETER STYLE GENERAL WITH NULLS;
>
>and explains:
>
>    For a UDF defined as in Example 15-10, the HLL
>    program will have four input parameter and one
>    output parameter, being the fourth a vector of
>    null indicators corresponding to the null state
>    for the first three parameters. The fifth
>    parameter corresponds to the null state for the
>    result the UDF will return.
>
>SQL Reference says that, after the input parms specified on the on the
>CREATE FUNCTION statement:
>     -> An additional argument is passed for an indicator variable array.
>     -> A parameter for the indicator variable for the result.
>How are these two items defined in SQL?  Are they implicitly defined?
>
>I guess I understand what I need to do in the RPG program and in the
CREATE
>FUNCTION statement, but what do I need to do to use the returned null
>indicator in an SQL statement that uses the UDF?  Can I even use this in
a
>SELECT statement?  I did not see a usage example in that redbook, nor in
the
>SQL Reference or SQL Programming manuals.
>
>TIA,
>Dan
>--
>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.



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

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.