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



Don't forget there could be hundreds of thousands of those "callbacks",
depending on the size and complexity of the XML document, assuming I
understand that is how XML-SAX works. The overhead of that large a number
of callbacks will likely vastly exceed the overhead of calling XMLTABLE a
few times if you had, for example, three sets to extract.

On Thu, Jul 13, 2017 at 12:17 PM, Nathan Andelin <nandelin@xxxxxxxxx> wrote:


Hi Nathan

I believe that we don't tell the SAX parser where to go get the
information - it goes from start to end of the XML "document" and returns
to a call-out procedure with various events, like start of document, end
of
element, stuff like that.


I understand that you don't tell XML-SAX which portions of an XML document
to parse. You specify the name of the procedure that the parser should call
when parsing events occur (i.e. when elements and attributes are found).

I was noting the difference with XMLTABLE, where you specify the name of
the XML element (which is normally an array of XML objects) to generate an
SQL cursor from.


You don't invoke the parser repetitively - at least, not the SAX parser
in
use with XML-SAX operation code.


That's right. Again I was noting the difference between parsers like
XML-SAX or Expat vs. XMLTABLE. You would call XMLTABLE repetitively, once
for each cursor that you want to generate, from each XML array that you
specify.

As I indicated before, single-pass parsing with XML-SAX or Expat would
probably run a lot more efficiently than the repetitive passes that one
would invoke when using XMLTABLE.


A programmer has to know the structure ahead of time, in order to create
reasonable sets of procedures to process each event type. And you need to
keep track of where you are in the tree as the parser calls your
procedure.

This IS a single pass - just lots of exits to the handling procedure you
specify.

Hope that makes sense and is even close to reality!!


Yes, I understand what you're saying. And hopefully you understand the
differences between XML-SAX and XMLTABLE.
--
This is the RPG programming on the IBM i (AS/400 and 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.

Please contact support@xxxxxxxxxxxx for any subscription related
questions.

Help support midrange.com by shopping at amazon.com with our affiliate
link: http://amzn.to/2dEadiD


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.