× 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 Joe,

> Just in case anyone is interested, I've just about gotten my
> benchmarking framework in place, and I've already run into some very
> interesting results.  I created a couple of programs, one that just does
> WRITEs, and one that does a number of different SQL techniques: INSERT
> VALUES, INSERT from data structure, INSERT from MODS.

On this topic, Paul Conte ran across the original thread in the MIDRANGE-L
archives regarding SQL vs. Native & benchmarking.  He had some
observations.  The following are his remarks to me -- these are his words
not mine, and I don't necessarily agree with everything he says.


Scott --

I read a bunch of the posts. Some observations:

** For an outdated, but more legitimate benchmark, see: "SQL/400 vs. RPG
IV: Which One's Faster?"  ID: 1956
http://www.iseriesnetwork.com/artarchive/index.cfm?fuseaction=viewarticle&CO_ContentID=1956&channel=art&subart=auth&authid=82

** The lack of basic SQL knowledge is dismaying. For example, Pluta puts a
Declare Cursor statement within a For loop. Seems like some respondents
suggested this would cause a performance hit. Well, Declare Cursor isn't an
executable statement, doesn't belong inside loops, but won't have any
performance impact regardless of where it's coded. The whole red herring
that "SQL isn't meant for record-level access" is BS. SQL is set-oriented,
and a set can consist of 1 (or 0 or more than 1) record. SQL is most
certainly designed to get single-record sets, i.e., single records. SQL
cursors are a mechanism for ordered retrieval (or as an iteration mechanism
for a set), and (especially using the SQL/400 support for array structures)
can perform quite well. Also, when a file has an index over field K and you
use the Open cursor / Fetch by = K / Close cursor technique, SQL/400 does
not generally actually open and close the cursor -- it just repositions the
file pointer. And, one last point, nobody seems to have mentioned that IBM
has completely replaced the OS/4000 query engine and this new engine is
used only for SQL access. All future IBM development efforts are going into
this new engine, so "native" I/O is sitting on system code that won't see
any improvements.

You may want to pass along that I've already written extensively on "SQL
vs. Native" in the Sep 6, 2001, Sep 20, Oct 4, Oct 18, and Nov 1 Club Tech
newsletters. (also a follow-up in Nov 15.) The series starts here:
http://www.iseriesnetwork.com/resources/clubtech/index.cfm?fuseaction=ShowNewsletterIssue&ID=11358

And, of course, my SQL/400 Developer's Guide and Powertips for iSeries
Database and SQL books (available from Penton) cover a lot of SQL basics.

Thanks again!

-- Paul

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.