Receive Updates



Sponsors

Keep in touch

About me

Oracle Applications Interface Programs

 ü       Order Import Interface

ü       Item Import (Item conversion)

ü On-hand Quantity

ü Customer Conversion

ü Customer API

ü Auto Invoice Interface

ü Receipt API

ü Auto Lockbox Interface

ü AP Invoice Interface

ü Vendor Interface/Conversion

ü Requisition Import

ü PO receipts interface

ü GL Interface

ü GL Budget Interface

ü GL Daily conversion rates

 

 

Order Import Interface (Sales Order Conversion)

 

          Interface tables:

·         OE_HEADERS_IFACE_ALL        

·         OE_LINES_IFACE_ALL                               

·         OE_ACTIONS_IFACE_ALL                           

·         OE_ORDER_SOURCES                      

·         OE_CUSTOMER_INFO_IFACE_ALL       

·         OE_PRICE_ADJS_IFACE_ALL    

·         OE_PRICE_ATTS_IFACE_ALL

         

          Base tables:  

·         OE_ORDER_HEADERS_ALL         

·         OE_ORDER_LINES_ALL

          Pricing tables          

·         QP_PRICING_ATTRIBUTES

 

          During import of orders, shipping tables are not populated.

 

If importing customers together with the order, OE_ORDER_CUST_IFACE_ALL

Base Tables: HZ_PARTIES    HZ_LOCATIONS

 

Orders can be categorized based on their status:

                   1. Entered orders              

2. Booked orders               

3. Closed orders

                  

Concurrent Program: Order Import

 

Validations:

·         Check for sold_to_org_id. If does not exist, create new customer by calling create_new_cust_info API.

·         Check for sales_rep_id. Should exist for a booked order.

·         Ordered_date should exist. -------- header level

·         Delivery_lead_time should exist. ----------- line level

·         Earliest_acceptable_date should exist.

·         Freight_terms should exist

 

Order Import API    OE_ORDER_PUB.GET_ORDER, PROCESS_ORDER

 

          Concurrent programs will in turn call APIs.

          2 APIs are called during order import process.

·         OE_CNCL_ORDER_IMPORT_PVT (cancelled orders)                    

·         ORDER_IMPORT_PRIVATE

          Procedure: import_order()

 

Item import (Item conversion)

Always import master and child records.

 

          Interface tables:     

·         MTL_SYSTEM_ITEMS_INTERFACE

·         MTL_ITEM_REVISIONS_INTERFACE(      If importing revisions, populate)

·         MTL_ITEM_CATEGORIES_INTERFACE(If importing categories, populate)

·         MTL_INTERFACE_ERRORS

 

          Item import can be run in create mode or update mode.  

Running the Item Open Interface In Create Mode:

Populate the mtl_system_items_interface with the following minimum required columns when creating new items:

PROCESS_FLAG = 1

TRANSACTION_TYPE = 'CREATE'

SET_PROCESS_ID = 1

ORGANIZATION_ID = Master Org id.

DESCRIPTION = 'Description of the item'

ITEM_NUMBER and/or SEGMENT(n)

 

Note:  Using the ITEM_NUMBER column in the mtl_system_items_interface is required if you are populating revision history data into the  mtl_item_revisions_interface table. The value of the ITEM_NUMBER must equal the concatenated segments(n) of the item being imported plus the segment separator.  If you are not importing revision history you can populate either ITEM_NUMBER or the SEGMENT(n) column(s) or both.

 

          Running the Item Open Interface In Update Mode:

To update existing item(s), set TRANSACTION_TYPE = 'UPDATE'.

 

For best performance, use inventory_item_id when updating items.

 

          Functionality

Every attribute updateable from the Item form is updateable through the interface, and all required validations are performed to enforce:

·         Item Attribute Interdependencies

·         Master - Child Attribute Dependencies

·         Status Controlled Attributes

·         Templates can be applied to existing Items. For best results, use template_id and template_name.

·         The Item status can be changed for existing Items, and the proper attributes are Defaulted / Set accordingly. The Status change is recorded in

MTL_PENDING_ITEM_STATUS.

·         To populate material costs from IOI: Populate the LIST_PRICE_PER_UNIT column with a value while importing items and you will see your material cost for your item in MTL_SYSTEM_ITEMS after running the Item Import process. (CREATE transaction_type only)

·         When launching items into the Master Item Org, the Child records are copied into MTL_SYSTEM_ITEMS_INTERFACE for validation, and are identified with transaction_type of 'AUTO_CHILD'. These records are deleted if the parameter 'Delete Processed Rows' has been passed as 'Yes', and remain for diagnostic purposes if the parameter is passed as 'No'. When the defining attribute for a Functional area is enabled, the proper default category set and category is assigned to the Item.

·         Master Items were loaded before child records in MTL_SYSTEM_ITEMS.

 

          Not Supported Issues

=========================================

·         Item Costs cannot be UPDATED (using "UPDATE" transaction_type) through the interface.

·         New Item revisions cannot be added to existing Items.

·         Current functionality does not support updates to a PTO MODEL ITEM through

the IOI update feature. See notes: 1076412.6 and 2121870.6 Updating Item Attributes to NULL The method to update these columns to NULL is to use the following values:

1.      for Numeric fields: insert -999999

2.      for Character fields: insert '!'

3.      for Date fields: the above list does not include any updateable date fields.

 

Importing Master and Child Records

==================================

          The user procedures are as follows :

1. Populate the item interface tables (mtl_system_items_interface). This step is necessary if you are creating items and categories in the same run. For importing item category assignments for already existing items, you do not need to populate item interface table.

2. Populate the item categories interface table (mtl_item_categories_interface).

 

The user needs to populate the following mandatory columns in item categories interface table:

A. Either inventory_item_id or item_number. When item and category are being imported together, then user can only specify the item_number, since item id will be generated by the import process.

B. Either organization_id or organization_code or both.

C. The transaction_type column should be 'CREATE'. We do not support 'UPDATE' or 'DELETE' for item category assignment.

D. Either category_set_id or category_set_name or both.

E. Either category_id or category_name or both.

F. Process_flag column as 1.

G. Populate the set_process_id column. The item and category interface records should have the same set_process_id, if you are importing item and category assignment together.

 

3. After populating the item and category interface tables, launch the Item Import process from the applications. In the item import parameters form, for the parameter 'set process id', specify the 'set process id' value given in the mtl_item_categories_interface table. The parameter 'Create or Update' can have have any value. Through the import process, we can only create item category assignment(s).

Updation or Deletion of item category assignment is not supported.

4. Once the concurrent process completes, check the mtl_interface_errors table for any error(s) during the item and category import. Correct those error conditions in the interface tables and run the item import again. If the process_flag is 7, that means the item category interface records were successfully imported.

 

Revisions

==============================

Note: Using the ITEM_NUMBER column in the mtl_system_items_interface table is required if you are populating revision data into the mtl_item_revisions_interface table. The value of the ITEM_NUMBER must equal the concatenated segments(n) of the item being imported, plus the segment separator. If you are not importing revision history you can populate either ITEM_NUMBER or the SEGMENT(n) column(s) or both. For historical item revision data, do NOT populate the REVISION column in the mtl_system_items_interface table. This column is used only if the current revision of the item is being imported.

Populate these columns in the mtl_item_revisions_interface table:

PROCESS_FLAG = 1

TRANSACTION_TYPE = 'CREATE'

SET_PROCESS_ID = 1

ORGANIZATION_ID = Master Org ID.

REVISION

EFFECTIVITY_DATE

IMPLEMENTATION_DATE

ITEM_NUMBER = (Must match the item_number in mtl_system_items_interface table.)

Each row in the mtl_item_revisions_interface table must have the REVISION and EFFECTIVITY_DATE in alphabetical (ASCII sort) and chronological order.

 

Run the IOI process. Navigate --> Inventory: Items: Import Items

There are 6 parameters to enter to begin the process:

1. Specify one or all organizations.

2. Validate items, yes or no.

3. Process items, yes or no.

4. Delete processed rows, yes or no.

5. Process set (null for all)

6. Create or update items (1 for create, 2 for update)

Note: If you are importing Master and Child records, insert them into the mtl_system_items_interface and mtl_item_revisions_interface tables, and run them at the same time by setting the 'All organizations' parameter to 'Yes'. If you do not do this, then the Child revision records will not be imported.

 

Error Checking:

======================================

When importing multiple revisions, if one record for an item fails validation, all revisions for that item fail. Resolve failed rows by checking the mtl_interface_errors table.

SELECT table_name, column_name, error_message, message_name

FROM mtl_interface_errors;

 

          Base tables:           

§         MTL_SYSTEM_ITEMS_B           

§         MTL_ITEM_REVISIONS_B

§         MTL_CATEGORIES_B                         

§         MTL_CATEGORY_SETS_B

§         MTL_ITEM_STATUS       

§         MTL_ITEM_TEMPLATES

 

Concurrent program:  Item Import

 

Validations:    check for valid item type.

          Check for valid part_id/segment of the source table.

          Validate part_id/segment1 for master org.

          Validate and translate template id of the source table.

Check for valid template id. (attributes are already set for items, default attributes for

that template, i.e., purchasable, stockable, etc)

          Check for valid item status.

          Validate primary uom of the source table.

          Validate attribute values.

          Validate other UOMs of the source table.

          Check for unique item type. Discard the item, if part has non-unique item type.

          Check for description, inv_um uniqueness

          Validate organization id.

 

Load master records and category records only if all validations are passed.

Load child record if no error found.

 

          Interface Tables                                            Base Tables

          MTL_SYSTEM_ITEMS_INTERFACE             MTL_SYSTEM_ITEMS

          MTL_TRANSACTIONS_INTERFACE             

          MTL_ITEM_REVISION_INTERFACE              MTL_ITEM_REVISIONS

          MTL_DEMAND_INTERFACE

          MTL_ITEM_CATEGORIES_INTERFACE                   MTL_ITEM_CATEGORIES

          MTL_CROSS_REFERENCES_INTERFACE       MTL_CROSS_REFERENCES

 

 

On-hand quantity

          Interface tables:      MTL_TRANSACTIONS_INTERFACE

                                      MTL_TRANSACTION_LOTS_INTERFACE      

                                      MTL_SERIAL_NUMBERS_INTERFACE

 

The Transaction Manager picks up the rows to process based on the LOCK_FLAG, TRANSACTION_MODE, PROCESS_FLAG to manipulate the records in the table. Only records with TRANSACTION_MODE of 3, LOCK_FLAG of '2', and PROCESS_FLAG of '1' will be picked up by the Transaction Manager and assigned to a Transaction Worker. If a record fails to process completely, then PROCESS_FLAG will be set to '3' and ERROR_CODE and ERROR_EXPLANATION will be populated with the cause for the error.

 

          Base tables:   MTL_ON_HAND_QUANTITIES

                             MTL_LOT_NUMBERS   MTL_SERIAL_NUMBERS

 

Concurrent program:

 

Validations:    validate organization_id, organization_code.

                   Validate inventory item id.

                   Transaction period must be open.

 

Customer conversion

Interface tables:      RA_CUSTOMERS_INTERFACE_ALL   

                             RA_CUSTOMER_PROFILES_INT_ALL                    

                             RA_CONTACT_PHONES_INT_ALL

          RA_CUSTOMER_BANKS_INT_ALL

          RA_CUST_PAY_METHOD_INT_ALL

 

Base tables:            HZ_PARTIES           

                             HZ_CONTACTS        

                             HZ_PROFILES                    

                             HZ_LOCATIONS

Base tables for RA_CUSTOMERS_INTERFACE_ALL

                            RA_CUSTOMERS                

                            RA_ADDRESSES_ALL

                            RA_CUSTOMER_RELATIONSHIPS_ALL        

                            RA_SITE_USES_ALL

         

          Uses TCA APIs.

 

Concurrent program: Customer Interface

 

          Validations:    Check if legacy values fetched are valid.

          ;                    Check if customer address site is already created.

                             Check if customer site use is already created.

                             Check is customer header is already created.

                             Check whether the ship_to_site has associated bill_to_site

                             Check whether associated bill_to_site is created or not.

          Profile amounts validation:   validate cust_account_id, validate customer status.

Check if the location already exists in HZ_LOCATIONS. If does not exist, create new location.

         

Customer API

1.      Set the organization id

Exec dbms_application_info.set_client_info(‘204’);

 

2.      Create a party and an account

HZ_CUST_ACCOUNT_V2PUB.CREATE_CUST_ACCOUNT()

HZ_CUST_ACCOUNT_V2PUB.CUST_ACCOUNT_REC_TYPE

HZ_PARTY_V2PUB.ORGANIZATION_REC_TYPE

HZ_CUSTOMER_PROFILE_V2PUB.CUSTOMER_PROFILE_REC_TYPE

 

3.      Create a physical location

HZ_LOCATION_V2PUB.CREATE_LOCATION()

HZ_LOCATION_V2PUB.LOCATION_REC_TYPE

 

4.      Create a party site using party_id you get from step 2 and location_id from step 3.

HZ_PARTY_SITE_V2PUB.CREATE_PARTY_SITE()

HZ_PARTY_SITE_V2PUB.PARTY_SITE_REC_TYPE

 

5.      Create an account site using account_id you get from step 2 and party_site_id from step 4.

HZ_CUST_ACCOUNT_SITE_V2PUB.CREATE_CUST_ACCT_SITE()

HZ_CUST_ACCOUNT_SITE_V2PUB.CUST_ACCT_SITE_REC_TYPE

 

6.      Create an account site use using cust_acct_site_id you get from step 5 ans site_use_code = ‘BILL_TO’.

HZ_CUST_ACCOUNT_SITE_V2PUB.CREATE_CUST_SITE_USE()

HZ_CUST_ACCOUNT_SITE_V2PUB.CUST_SITE_USE_REC_TYPE

HZ_CUSTOMER_PROFILE_V2PUB.CUSTOMER_PROFILE_REC_TYPE

 

Base table:   

·         HZ_PARTIES                

·         HZ_PARTY_SITES         

·         HZ_LOCATIONS

·         HZ_CUST_ACCOUNTS    

·         HZ_CUST_SITE_USES_ALL

·         HZ_CUST_ACCT_SITES_ALL     

·         HZ_PARTY_SITE_USES

 

Validations:    Check if legacy values fetched are valid.

                             Check if customer address site is already created.

                             Check if customer site use is already created.

                             Check is customer header is already created.

                             Check whether the ship_to_site has associated bill_to_site

                             Check whether associated bill_to_site is created or not.

          Profile amounts validation:   validate cust_account_id, validate customer status.

Check if the location already exists in HZ_LOCATIONS. If does not exist, create new location.

 

Auto Invoice interface

          Interface tables:      RA_INTERFACE_LINES_ALL

 

Base tables:           

 

Concurrent Program: Auto invoice master program

 

          Validations: check for amount, batch source name, conversion rate, conversion type.

                            Validate orig_system_bill_customer_id, orig_system_bill_address_id, quantity.

                             Validate if the amount includes tax flag.

 

Receipt API

AR_RECEIPT_API_PUB.CREATE_CASH

AR_RECEIPT_API_PUB.CREATE_AND_APPLY

 

To bring in Unapplied Receipts and Conversion Receipts for Open Debit items to reduce the balance to the original amount due.

 

          Base tables:   AR_CASH_RECEIPTS

 

Validations:    check the currency and the exchange rate type to assign the exchange rate.

                   Validate bill to the customer.

                   Get bill to site use id.

                   Get the customer trx id for this particular transaction number.

                   Get payment schedule date for the customer trx id.

 

Lockbox interface

          Interface tables:      AR_PAYMENTS_INTERFACE_ALL (Import data from bank file )

 

Base tables:            AR_INTERIM_CASH_RECEIPTS_ALL   AR_INTERIM_CASH_RCPT_LINES_ALL (Validate data in interface table and place in quick cash tables)

 

Related Tables:        AR_BANK_ACCOUNTS_ALL    AR_RECEIPT_METHODS

AR_TRANSMISSIONS_ALL     HZ_CUST_ACCOUNTS          HZ_CUST_SITE_USES_ALL           AR_CASH_RECEIPTS

(POST QUICK CASH -- applies the receipts and updates customer balances)

Concurrent program: nav-> receivables->interfaces->lockbox

         

Validations:    check for valid record type, transmission record id.

                   Validate sum of the payments within the transmission.

                   Identify the lockbox number (no given by a bank to identify a lockbox).

 

AP invoice interface

Interface tables:      AP_INVOICES_INTERFACE    AP_INVOICE_LINES_INTERFACE

                            

          Base tables:            AP_INVOICES_ALL – header information

                             AP_INVOICE_DISTRIBUTIONS_ALL – lines info

 

Concurrent program: Payables Open Interface Import

 

          Validations:    check for valid vendor

                             Check for valid vendor site code.

                             Check if record already exists in payables interface table.

                  

Vendor conversion/interface

          No interface tables

 

          Base tables:   PO_VENDORS           PO_VENDOR_SITES_ALL

                            

No concurrent program as data is directly populated into base tables.

         

          Validations:    check if a vendor already exists with the same name as the TIMSS customer

mail name.

Check if the proper site code and id exists based on the site code from TIMSS.

Check for uppercase value of the vendor name existed in Oracle and in TIMSS, vendor name is mixed case, a new Oracle vendor will not be created.

         

Purchasing:

          Interface Tables                                  Base Tables

          PO_HEADERS_INTERFACE                         PO_HEADERS_ALL

          PO_LINES_INTERFACE                             PO_LINES_ALL

          PO_REQUISITIONS_INTERFACE_ALL PO_REQUISITIONS_HEADERS_ALL

                                                                   PO_REQUISITION_LINES_ALL

                                                                   PO_REQ_DISTRIBUTIONS_ALL

          PO_REQ_DIST_INTERFACE_ALL                 PO_REQ_DISTRIBUTIONS_ALL

          PO_DISTRIBUTIONS_INTERFACE                PO_DISTRIBUTIONS_ALL

          PO_RESCHEDULE_INTERFACE                   PO_REQUISITION_LINES_ALL

 

Requisition import

          Interface tables:      PO_REQUISITIONS_INTERFACE_ALL

                                      PO_REQ_DIST_INTERFACE_ALL                

 

          Basetables:  PO_REQUISITIONS_HEADERS_ALL                                                   

                            PO_REQUISITION_LINES_ALL     

                            PO_REQ_DISTRIBUTIONS_ALL