I would have created an LF omitting the unsupported data types, as matter of course, in anticipation of that error msg CPF428A RC1, because I know I might want to use non-SQL access. Perhaps JDE may have done the same for its PF, possibly, because they may have their own /native/ I\O requirements which would have encountered the same difficulty [restriction]. Perhaps review the DSPFFD of the relations in the output of DSPDBR RCDFMT(*NONE) that are not in the output of DSPDBR RCDFMT(*ALL) against the JDE physical file. Note: A query of the *DBXREF dependencies and column data could be done instead of using the Display Database Relationships (DSPDBR) output, to determine if a there exists a record format defined without the unwanted column name(s) or data types.

The C language has a capability to effect an open using the "process large object fields specified in the program" for the UFCB. That is of no help directly to the RPG unless the same capability is exposed via the RPG as well, because a shared open would still fail, just like the full open, but with the error msg CPF417C RC6 instead of the CPF428A. And deferring the work to the C vs to the SQL is probably not necessarily any better as a solution. And obviously, if the capability is [were to be] exposed via the RPG, then no reason to defer to the C [for its _Ropen lobptrs=Y capability].
http://archive.midrange.com/c400-l/201111/msg00013.html

The LF could be created into QTEMP versus being created as a permanent file [in the library of the PF, or spanning libraries in its relations]. While Mark alluded to CRTLF or CREATE VIEW, the CREATE INDEX has the capability to define the record format as well. Given the same or otherwise compatible access path definition, the AccPth of the existing file is shared; i.e. no actual access path is built\created for the SQL INDEX, so there would be no storage or CPU concerns. I had written a procedure that I called VIEW_OF effectively to issue CREATE VIEW QTEMP/specified-name ON a TALBE (or VIEW) name given in one parameter, and with a parameter was a capability to define the columns to be omitted; an omission could be implied however, to implicitly effect removing any columns from the select-list for which their data types prevent access via typical RLA. And the same idea could be extended to the CREATE INDEX, but instead of a select-list, using its RCDFMT clause; i.e. ADD KEYS ONLY or ADD column-name syntax to specify the list of columns to be included beyond those implicitly included on the key-expression clause.
<http://pic.dhe.ibm.com/infocenter/iseries/v7r1m0/topic/db2/rbafzxcindx.htm>
_CREATE INDEX_
"The CREATE INDEX statement creates an index on a table at the current server. ..."

Instead of an LF, and much like the SQL UPDATE vs native\RLA I/O as seemingly silly, the use of an Open Query File (OPNQRYF) creates only a temporary ODP. The FORMAT() specified on the OPNQRYF request would be the equivalent of what the LF would be, if that Logical File were used to resolve the issue instead. The Record Format could be a PF, even without a member; of course the same keys as the LF. The KEYFLD(*FILE) and really nothing more than the QRYFILE() specification, the /query/ ODP should act almost exactly like an LF; i.e. like and more explicitly than with CREATE INDEX, there should be no access paths built, so no storage or CPU concerns as compared to using an existing\permanent LF. Of course the query ODP must be effected using sharing, SHARE(*YES), so the RPG open connects with the ODP referring to the Record Format that omits the undesirable columns; lacking a CLP controlling the activation of the RPG, a named activation is best, so the [presumed to be necessary] override can be scoped to the named ACTGRP vs scoping to the job which is undesirable.
http://archive.midrange.com/rpg400-l/201204/msg00319.html

Regards, Chuck

On 21-Dec-2013 10:05 -0800, Richard Schoen wrote:
<<SNIP>>
I ended up just using an SQL update, but silly to have to compose an
SQL update when I have a unique key already :-)

I like your idea and it has merit too. I just didn't want to be
creating logicals over a JDE table since this is a process that will
run regularly and needs filtering.

I guess I'll just have to get use to the fact that sometimes using
SQL for all the I/O is the way to go :-)

On Sat, 21 Dec 2013 12:25:44 -0500 Mark S Waterbury wrote:

How about this approach:

1. create a logical file (or view) over that table that omits the
BLOB field, since you say your program will not be using it?
2. then, your program just uses the logical file, instead of
directly accessing the physical file.
3. if needed, you could even provide QDDSSRC and issue CRTLF to
create the (temporary) logical file (or SQL DDL source to create
the SQL view) in QTEMP, when the program runs...
<<SNIP>>

On 12/21/2013 12:14 PM, Richard Schoen wrote:

Working to create an RPGLE program that uses a JD Edward/Oracle
E1 V9.1 table and it has a blob field in it.

Getting CPF428A when the program attempts to implicitly open the
file as defined in the F spec.

I can get around it by using SQLRPGLE and omitting the blob
field, but is there a way to get a regular RPGLE program to
process a table with a blob field ?

I don't plan to use the field, but it's in the table.

I did google and checked the list, but didn't see a clear
resolution for this.

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.