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



Hi Birgitta,

Thanks for the feedback.

Sounds like you've summarized it. Data structures for internal usage and JSON for external usage.

I was inspired by a discussion with Marina Schwenk the other day on her IBMiUnit testing component.
https://github.com/MarinaSchwenk/IBMiUnit

I started thinking about ways to make existing RPG code more flexible for both internal app use (In existing RPG apps that run in batch or green screen) and web apps and services (which typically require JSON or XML interaction and output).

When I write in .Net, Java, etc it's easy to return result sets, so I started thinking about the best way to simulate that in RPG.

In RPG we're trying to promote subprocedures, but in todays world of modernization I think of making all my code flexible enough to work in screen applications or web applications and services as well.

On the side of stored procedure usage I may have an unpopular opinion, but I've always kept my database code as simple as possible and relied on the business layer to contain the business logic. Since RPG is so easy to call as a sproc that's worked well for me. I also have experienced the nuances of MySql and SQL Server and Oracle on other platforms and they each have specific things to think about so I've always kept DB access as simple as possible in the business tier.

Thanks again for the input.

Regards,
Richard Schoen
Web: http://www.richardschoen.net
Email: richard@xxxxxxxxxxxxxxxxx

------------------------------

message: 2
date: Fri, 31 Jan 2020 05:51:15 +0100
from: "Birgitta Hauser" <Hauser@xxxxxxxxxxxxxxx>
subject: RE: Returning Resultsets from RPG Subprocedures

If you are only working with RPG for externalizing Data Access, I'd suggest returning the result as Data structure.
Returning the result as JSON makes it more flexible, especially when calling from other programming languages, but the JSON data must be parsed on the other side.

... just as an aside, try to move as much logic into the database, i.e. use
(complex) views, user defined (table) functions and other database techniques to reduce your (RPG) source code to a minimum.

Mit freundlichen Gr??en / Best regards

Birgitta Hauser


"Shoot for the moon, even if you miss, you'll land among the stars." (Les
Brown)
"If you think education is expensive, try ignorance." (Derek Bok) "What is worse than training your staff and losing them? Not training them and keeping them!"
?Train people well enough so they can leave, treat them well enough so they don't want to.? (Richard Branson)


-----Original Message-----
From: RPG400-L <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of Richard Schoen
Sent: Donnerstag, 30. Januar 2020 19:03
To: rpg400-l@xxxxxxxxxxxxxxxxxx
Subject: Returning Resultsets from RPG Subprocedures

Hey RPG folks,

In thinking about using RPG subprocedures and service programs for querying individual records and record sets, what would be the best way to call a subproc that returns a resultset and have it return the data to the calling program ?

For my discussion the calling program could be another Green Screen app or a web app.

What are my options for most universal DB access code re-use ?
-Return as data structure ?
-Return as JSON or XML packet ?
-Write to temp DB table ?
-What about actually returning the results object ?

I suppose just using copy books is an option to include at the code level on-the-fly.

Insight appreciated since I don't do as much RPG as I used to.

Thanks

Regards,
Richard Schoen
Web: http://www.richardschoen.net<http://www.richardschoen.net/>
Email: richard@xxxxxxxxxxxxxxxxx<mailto:richard@xxxxxxxxxxxxxxxxx>

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.