On 23-Feb-2012 15:35 , dmosley@xxxxxxxxxx wrote:
I've encountered similar problems, but we resolved it by
doing the reverse, of O-ALL to S-ALL.
Try this.
A CODEV I SST(DOCODE 1 2)
A K RRAKCN
A K RRAKYR
A K RRAKTY
A K RRAKNO
A O STATUS COMP(EQ 'X')
A O CODEV COMP(NE 'EV')
A S ALL
"Shannon ODonnell" on 02/23/2012 06:17 PM wrote:
Did not work. Here's the actual code. It's still pulling in
everything, not just where my CODEV (derived field) = 'EV'
<<SNIP>>
A S STATUS COMP(NE 'X')
A S CODEV COMP(EQ 'EV')
<<SNIP>>
Perhaps in thought the resolution was by reverse logic [for each of
the "OR"ed Select comparisons in the prior message], but possibly only
because the *OR is appropriate, when thinking about what to Omit versus
what to Select.? While the given omit logic is presumably correct for
what the OP wants, the important aspect for defining the proper Select
logic in the DDS is knowing what determines [i.e. how to specify] "AND"
and what determines "OR" between the specifications.
_i Select/omit field name i_
http://publib.boulder.ibm.com/infocenter/iseries/v5r4/topic/rzakb/selectomit.htm
"
You use select/omit fields to tell the operating system how to select or
omit records when your program retrieves them using this record format.
...
When using the select/omit fields, specify either S or O in position 17.
By specifying either S or O, the select and omit comparison statements
are joined by OR. The system treats the select and omit comparison
statements that are joined by OR independently from one another. That
is, if the select or omit comparison condition is met, the record is
either selected or omitted. If the condition is not met, the system
proceeds to the next comparison.
By specifying a blank in position 17, the select and omit comparison
statements are joined by AND. The combined comparisons must be met
before the record is selected or omitted.
...
"
The "Omit" logic in the "15:35" message will Select:
*NOT ( (STATUS *EQ 'X') *OR (CODEV *NE 'EV') )
That is the equivalent of the following "Select" [and probably the
desired] logic:
(STATUS *NE 'X') *AND (CODEV *EQ 'EV')
However, note that the logic that "Did not work" was:
(STATUS *NE 'X') *OR (CODEV *EQ 'EV')
That logic which "Did not work" would include all "EV" for CODEV
irrespective of the value of STATUS, and would include all non-"X"
STATUS values irrespective of the value of CODEV... thus including many
unwanted records [though not necessarily "everything"] rather than only
those records where "CODEV (derived field) = 'EV'".
Regards, Chuck
As an Amazon Associate we earn from qualifying purchases.