> From: Paul Holm

Paul, I'm not going to get into a long discussion here.  I am going to
address a couple of your issues, and then I'm going to discuss a larger
issue which is constantly missed when people talk about this.


> d)       It doesn't leverage the power of SQL/JDBC.  Using dataqueues,
how
> do you get the data back and forth from mother to children?

I'm not sure where you got the idea that I couldn't or wouldn't use SQL.
The server can do whatever it wants to do in the background.  As to the
power of JDBC, what exactly IS the "power of JDBC"?  If you haven't
figured it out yet, I'm about to start a tirade against buzzwords and
FUD.


> d.       Many, many other features that SQL provides by default.

As I said, the server can use SQL.  So can we just wipe out this entire
round of "reasons"?


> e)       Multiprocessing.  Would this architecture restrict us to each
> child
> server program synchronously handling each DQ request?  JDBC would
allow a
> multi-threaded approach.

The next bit of FUD.  Paul, please provide a real way this improves
performance on the iSeries.  Since I could just as easily have multiple
child server jobs, the multi-threading issues are moot.  Please,
multiprocessing is what the iSeries does best.


> d.       In a mixed model with Java calling RPG, how do you get these
> business rules available to be leveraged by your UI?  Do you have to
now
> kinda of create a dual business model logic?

If it's a business attribute, it gets derived in the server and passed
in the message.  If it's purely presentation logic rather than business
logic, then it belongs in the UI.  Or are you unclear as to how that
works?  This is a really specious argument.


> g)       Non strategic approach.  IBM and the industry are investing
in
> SQL/JDBC/Java and much less in native IO and dataqueues.  Long term
> maintenance of RPG may be an issue as skill bases become dominated by
> Java.

This is definitely FUD.  We've been hearing about the death of RPG and
the IBM midrange for nearly 30 years now.  Please find another dead
horse to beat.


> You are also not able to fully leverage the growing array of JDBC
based
> persistence APIs and other Java components.

More FUD!  The Java components I want (the UI stuff) are all available
in a JSP/servlet UI.  As to persistence APIs, the best ones they have
are stuff like Hibernate, which is write-cached, which means if you lose
your JVM you lose your updates!

WHY WHY WHY WHY would I want to move my mission critical systems from a
native I/O environment with almost zero faults to something that can
lose data anytime the JVM hiccups?


> h)       Productivity or a lack of it.  I may be missing something,
but I
> don't understand how a procedural approach to persistence in RPG along
> with
> business rules procedurally enforced can be done in a productive,
flexible
> manner.  I may be missing something but typically we can create the
basic
> functionality that Aaron mentions (A/R inquiry, updates, Sales,
Security
> based on client,etc) in a day or two.  How long would it take us in
this
> procedural model?

Okay, now on to this stuff.

Paul, you can create a nice file maintenance suite in a quick manner.
So can anybody.  I can do the same thing with a few decent skeleton
programs.  In fact, I can set up an entire client/server system in about
two days that has people cranking out applications with far more
capabilities than your stuff.  I just did it for one of my clients, and
they're thrilled with the speed (not to mention the security).

The problem with code generators is that they tend to code the 80% of
the function that takes 20% of the time.  But then you're left with the
20% of the programming that takes 80% of the time: stuff like
hierarchical pricing structures, by-product analysis, standard cost
rollups, MRP generations, WIP costing, line scheduling and all of the
other stuff that actually requires more knowledge than looking at a
field definition and figuring out how to show it on the screen.

What I'd LIKE to do is to ask that from this point forward we separate
business applications into a few simple categories:

1. Master File Maintenance

This includes the Work With types of inquiries, as well as the popups
for valid values and all that crap that we're used to in our file
maintenance programs.

2. Enterprise Information Inquiries

These are inquiries that support JOINS among multiple files, with
various levels of totals and breakouts, the ability to drill into
values, the ability to easily change selection and order criteria, and
so on.  Add-ons are PDF and XLS generation (and nowadays XML
generation!), email capabilities, web services interface, graphing and
so on.

3. Transaction Processing

This involves any of the meat and potatoes types of programming that
actual requires programming above the junior level.  MRP generations and
line load scheduling are great examples.  Pricing algorithms, even sales
forecasts, can all fall into this category.  This sort of processing is
driven by database flags, typically retrieved from various levels of
master files.  Processing is intense and rules-based, and the rules are
often changeable based on external conditions.

With these three types of processing, it's clear that different tools
are probably better for different jobs.  For example, some sort of tool
can be used to generate master file maintenance programs; we've been
doing that for years both with generators and with skeleton programs.
The current generation of application development tools make this
particularly easy.  The EII class of applications is almost certainly
best done with an SQL approach, and depending on issues of security and
scalability, a pure JDBC approach may be in order.  But for the third
classification of transaction processing, I am still clearly convinced
that procedural languages and specifically RPG are more flexible, more
maintainable, and more productive than OO languages.

Joe


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.