1.Functional Description
1.1Purpose
This function will perform Get, Add, Update, Delete, Delete All, Get Next, Add/Update, and Terminate
functions on the MRP Work Order Cache used in the MRP/MPS planning programs (P3482 and P3483).
The calling application is responsible for loading all appropriate key values to the data structure
and identifying the number of keys to use in retrieval/update processes.
1.2 Setup Notes and Prerequisites
Cache Action Code
'2' Add - add a cache element.
'3' Update - update a cache element.
'4' Delete - delete a cache element.
'5' Delete All - delete all cache elements
'6' Get Next - retrieve the next cache element
'7' Add/Update - will add if element does not exist, will change if it does exist.
'8' Terminate - terminate cache
'9' Close cursor and free ptr.
'N' Get Nearest - Retrieve the cache element matching the input Item, Branch and Date. If the
element does not exist, retrieve the element with the date immediately before or after based on the
input Comparison Flag.
'D' Debug Mode - Dumps the contents of the entire cache into a text file
Number of Keys
key values for a Get, Update, Delete, Get Next, and Add/Update.
A zero may be passed to retrieve, update, or delete the first record.
When action code GET is used, the function saves the cache cursor pointer if the fetch is successful
and SequentialFetch = '1'. This allows the calling application to use GET NEXT to fetch elements
from the cache sequentially. If GET NEXT is called until the end of the keyed cache dataset is found,
the function automatically closes the open cursor.
1.3Special Logic
This function creates a unique cache for each MRP/MPS planning process. The function appends the
input Job Number string to the two character ID 'WO' to build the cache name used for the calling
application.
2.Technical Specifications
Cache Layout:Cache includes all of the following fields; key fields are noted.
Data Item Data Structure DescriptionKey Field
ITMShort Item NumberY
MMCUBranchY
DRQJRequested DateY
DOCOOrder Number
DCTOOrder Type
SRSTStatus
STRTStart Date
UORGOpen Quantity
MATH01Work Order Quantity
TBMType Of Bill
EV01Expedite Flag
I.Perform setup functions
B.If not successful, set error "032E", set Cache Error Code = '3', and return failure.
C.Set Cache Error Code = '0'
D.Set return code to success.
II.Processing Based on Mode.
2.Retrieve the first element on the cache matching the key values passed as input. If the
input Number of Keys is zero, fetch the first element in the cache.
3.Load the values from the retrieved element into the data structure to be passed back to
the calling program.
4.If SequentialFetch is '1', return the cursor pointer to the calling application.
Otherwise, close the cursor.
5.If get fails set Cache Error Code = '6'.
2.If add fails set error "032E", set Cache Error Code = '4', and return failure.
2.If update fails set error "032E", set Cache Error Code = '4', and return failure.
passed as input.
2.If the number of keys is 0, delete the first cache element.
3.If delete fails, set Cache Error Code = '5'.
E.If Cache Action Code is '5' - DELETE ALL:
2.If delete fails, set Cache Error Code = '5'.
cursor pointer must be provided by a previous "Get" action, i.e. Cache Action Code '1'. If the
Number of Keys is zero then fetch the next record without using any key.
2.Load the values from the retrieved element into the data structure to be passed back to
the calling program.
3.If there are no more elements, close the cursor, remove the cursor pointer from the BsFn
data structure, and set Cache Error Code = '1'.
G.If Cache Action Code is '7' - ADD/UPDATE:
2.Insert a new cache element with values from data structure.
3.If add fails set error "032E", set Cache Error Code = '4', and return failure.
2.Retrieve the first element in the cache matching the key values passed as input. The
input Number of Keys must be 3. (ITM, MCU, DRQJ)
3.If successful, load the values from the retrieved element into the data structure to be
passed back to the calling program and return success.
4.If not successful, Reset cursor.
5.Using just the input Item and Branch as the key, search for the cache element with the
desired date based on the input Direction Flag:
'A' = retrieve the cache element occurring just after the input Date
the calling program. Close the cursor.
7.If get fails set Cache Error Code = '6'.
2.Close Cursor
3.Free Ptr
4.Set Cache Cursor Ptr = 0
^
D3401310 - Cache, Process MRP Work Orders
Data Item Data Structure DescriptionI/ORequiredNotes
JOB Job Number IY Job Number as string for
cache name
ITM Short Item Number I/OY key value
MMCU Branch I/OY key value
DRQJ Requested Date I/OY key value
DOCO Order Number I/OY
DCTO Order Type I/OY
SRST Status I/OY
STRT Start Date I/OY
UORG Open Quantity I/OY converted to primary UOM
MATH01 Work Order Quantity I/OY WAUORG
TBM Type Of Bill I/OY
EV01 Expedite Flag I/OY '1' - WO has already been
expedited
EV02 Cache Action Code IY '1' = Get cache element
'2' = Add element
'3' = Update element
'4' = Delete cache elements
'5' = Delete All cache
elements
'6' = Get Next cache element
'7' = Add/Update cache
element
'8' = End cache (terminate
cache)
'9' = Close Cursor and Free
Ptr
'N' = Get Nearest
'D' = Dump cache into text
file
EV01 Cache Error Code ON '0' = Success Process
'1' = Reached End of
Cache(mode 6)
'2' = Invalid Input Parameter
'3' = Failed to Create Cache
'4' = Failed to Add/Update
Cache
'5' = Failed to Delete Cache
'6' = Fetch Failed(mode 1 or
9)
EV01 Comparison Flag I Only used for action code
'9':
'B' = get cache element
w/Date <=
input date
'A' = get cache element
w/Date >=
input date
INT01 Number of Keys IY Number of Keys to be used in
the
cache process.
SUPPS Suppress Error Message IN '0'= allow runtime error
message
handling.
'1'= Suppress runtime error
message
handling.
DTAI Error Message Id ON " " = Success
"032E" = Error Processing
Cache
GENLNG Cache Cursor Ptr I/ON
EV02 Sequential Fetch I/ON If action is GET and this
parm is
'1', function will pass back
cursor
pointer for GET NEXT
operation.
^
Parameter Name | Data Item | Data Type | Req/Opt | I/O/Both |
---|---|---|---|---|
szJobNumber | JOB | char | NONE | NONE |
Job Number | ||||
mnShortItemNumber | ITM | MATH_NUMERIC | NONE | NONE |
An inventory item number. The system provides three separate item numbers plus an extensive cross-reference capability to other item
| ||||
szBranch | MCU | char | NONE | NONE |
An alphanumeric code that identifies a separate entity within a business for which you want to track costs. For example, a business unit
| ||||
jdDate | DRQJ | JDEDATE | NONE | NONE |
The date that an item is scheduled to arrive or that an action is scheduled for completion. | ||||
mnOrderNumber | DOCO | MATH_NUMERIC | NONE | NONE |
A number that identifies an original document. This document can be a voucher, a sales order, an invoice, unapplied cash, a journal entry,
| ||||
szOrderType | DCTO | char | NONE | NONE |
A user defined code (00/DT) that identifies the type of document. This code also indicates the origin of the transaction. J.D. Edwards has
| ||||
szStatus | SRST | char | NONE | NONE |
A user defined code (00/SS) that describes the status of a work order, rate schedule, or engineering change order. Any status change from
| ||||
jdStartDate | STRT | JDEDATE | NONE | NONE |
The start date for the order. You can enter this date manually, or have the system calculate it using a backscheduling routine. The routine
| ||||
mnOpenQuantity | UORG | MATH_NUMERIC | NONE | NONE |
The quantity of units affected by this transaction. | ||||
mnWorkOrderQuantity | UORG | MATH_NUMERIC | NONE | NONE |
The quantity of units affected by this transaction. | ||||
szTypeOfBill | TBM | char | NONE | NONE |
A user defined code (40/TB) that designates the type of bill of material. You can define different types of bills of material for different uses.
| ||||
cExpediteFlag | EV01 | char | NONE | NONE |
An option that specifies the type of processing for an event. | ||||
idCacheCursorPtr | GENLNG | ID | NONE | NONE |
General purpose ID variable. | ||||
cSequentialFetch | EV02 | char | NONE | NONE |
An option that specifies the type of processing for an event. | ||||
cCacheActionCode | EV02 | char | NONE | NONE |
An option that specifies the type of processing for an event. | ||||
cCacheErrorCode | EV01 | char | NONE | NONE |
An option that specifies the type of processing for an event. | ||||
nNumberOfKeys | INT01 | integer | NONE | NONE |
Number of Days in Future to Query for Responses Due. | ||||
cSuppressErrorMessage | SUPPS | char | NONE | NONE |
A flag indicating whether or not runtime error messaging will occur when an error message is issued from a business function.
0 = allow
| ||||
szErrorMessageID | DTAI | char | NONE | NONE |
A code that identifies and defines a unit of information. It is an alphanumeric code up to 8 characters long that does not allow blanks or
| ||||
cComparisonFlag | EV01 | char | NONE | NONE |
An option that specifies the type of processing for an event. | ||||
jdDateSave | DRQJ | JDEDATE | OPT | NONE |
The date that an item is scheduled to arrive or that an action is scheduled for completion. | ||||
cDeferFlag | EV01 | char | OPT | NONE |
An option that specifies the type of processing for an event. | ||||
nIndexNumber | INT02 | integer | OPT | NONE |
Number of Days in the Past to Query for Quote Requests Received. | ||||
jdDateRecommendedStart | RSTJ | JDEDATE | OPT | NONE |
The recommended start date for an order. | ||||
jdRecommendedDeliveryDate | REDJ | JDEDATE | OPT | NONE |
The date that the system produces when you respond to an MRP message that contains a recommended date. | ||||
jdDateRequestedSave | DRQJ | JDEDATE | OPT | NONE |
The date that an item is scheduled to arrive or that an action is scheduled for completion. | ||||
jdOriginalEffectiveDateSaved | OEDJ | JDEDATE | OPT | NONE |
A purchase item's original effective date for a lot controlled item. MRP messages use this field to alert users to review the MRP time series
|
None |
None |