Friday, September 20, 2013

Data flow for Order-to-Cash cycle





1. Order Entry
This is first stage, When the order is entered in the system, it creates a record in order headers and Order Lines table.
·        Enter header details: Once you enter details on the order header and save it or move it to  
         lines, record goes to one table oe_order_headers_all.
             .        No record exists in any other table for this order till now.
·        Enter Line details for this order: Enter different item numbers, quantity and other details
         in line tab. When the record gets saved, it goes to one table. Order header details will be
         linked with line details by order HEADER_ID.
2. Order Booking
This is next stage, when Order is booked then the Flow status changed from Entered to Booked. At this stage, these below table get affected.
·        oe_order_headers_alL
·        oe_order_lines_all
·        wsh_delivery_details
·        wsh_delivery_assignments
*In shipping transaction form order status remains “Ready to Release”.
At the same time, Demand interface program runs in background and insert into inventory tables mtl_demand.
3. Reservation
This step is required for doing reservations SCHEDULE ORDER PROGRAM runs in the background and quantities are reserved. Once this program get successfully get completed, the mtl_demand and mtl_reservations table get updated.
4. Pick Release
Pick Release is the process of putting reservation on on-hand quantity available in the inventory and pick them for particular sales order.
Pick release can be done from ‘Release Sales Order’ form or ‘Pick release SRS’ program can be scheduled in background. In both of these cases all lines of the order gets pick released depending on the Picking rule used. If specific line/s needs to be pick release it can be done from ‘Shipping Transaction form. For this case Pick Release is done from ‘Release Sales Order’ form with Pick Confirm=NO.
Once pick release is done these are the tables get affected:
·        If step 3 is not done then MTL_RESERVATIONS gets updated now.
·        wsh_new_deliveries
·        wsh_delivery_assignments
·        wsh_delivery_details
·        MTL_TXN_REQUEST_HEADERS
·        MTL_TXN_REQUEST_LINES
·        Mtl_material_transactions_temp
·        MTL_SERIAL_NUMBERS_TEMP
·        MTL_SERIAL_NUMBERS
*In shipping transaction form order status remains “Released to Warehouse” and all the material still remains in source sub-inventory. We need to do Move Order Transaction for this order. Till this no material transaction has been posted to MTL_MATERIAL_TRANSACTIONS
5. Pick Confirm/ Move Order Transaction
Items are transferred from source sub-inventory to staging Sub-inventory. Here material transaction occurs.
Order line status becomes ‘Picked’ on Sales Order and ‘Staged/Pick Confirmed’ on Shipping Transaction Form.
·        MTL_MATERIAL_TRANSACTIONS_TEMP
·        oe_order_lines_all
·        MTL_MATERIAL_TRANSACTIONS
·        mtl_transaction_accounts
·        wsh_delivery_details
·        wsh_delivery_assignments
·        MTL_ONHAND_QUANTITIES
·        MTL_SERIAL_NUMBERS_TEMP
·        MTL_SERIAL_NUMBERS
* This step can be eliminated if we set Pick Confirm=YES at the time of Pick Release 
6. Ship Confirm
Here ship confirm interface program runs in background. Data removed from wsh_new_deliveries. 
The items on the delivery gets shipped to customer at this stage.
·        oe_order_lines_all
·        wsh_delivery_details
·        WSH_SERIAL_NUMBERS
·        mtl_transaction_interface
·        mtl_material_TRANSACTIONS
·        mtl_transaction_accounts
·        mtl_demand, MTL_reservations
·        MTL_ONHAND_QUANTITIES
·        MTL_SERIAL_NUMBERS_TEMP
·        MTL_SERIAL_NUMBERS
7. Enter Invoice 
After shipping the order the order lines gets eligible to get transferred to RA_INTERFACE_LINES_ALL. Workflow background engine picks those records and post it to RA_INTERFACE_LINES_ALL. This is also called Receivables interface, that mean information moved to accounting area for invoicing details. Invoicing workflow activity transfers shipped item information to Oracle Receivables. At the same time records also goes in the table RA_INTERFACE_SALESCREDITS_ALL which hold details of sales credit for the particular order.
ra_interface_lines_all (interface table into which the data is transferred from order management) Then Auto-invoice program imports data from this table which get affected into this stage are receivables base table. At the same time records goes in ra_customer_trx_all and ra_customer_trx_lines_all
8. Complete Line
In this stage order line level table get updated with Flow status and open flag.
oe_order_lines_all
9. Close Order
This is last step of Order Processing. In this stage only oe_order_lines_all table get updated. These are the table get affected in this step.

oe_order_lines_all
oe_order_HEADERS_all


1. Order Entry
This is first stage, When the order is entered in the system, it creates a record in order headers and Order Lines table.
·        Enter header details: Once you enter details on the order header and save it or move it to lines, record goes to one table oe_order_headers_all flow_status_code = ENTERED, booked_flag = N), Primary key=HEADER_ID
o        No record exist in any other table for this order till now.
·        Enter Line details for this order: Enter different item numbers, quantity and other details in line tab. When the record gets saved, it goes to one table. Order header details will be linked with line details by order HEADER_ID. oe_order_lines_all (flow_status_code = ENTERED, booked_flag = N, open_flag = Y) Primary key= LINE_ID
2.Order Booking
This is next stage, when Order is booked then the Flow status changed from Entered to Booked. At this stage, these below table get affected.
·        oe_order_headers_alL (flow_status_code as BOOKED, booked_flag updated to Y)
·        oe_order_lines_all (flow_status_code as AWAITING_SHIPPING, booked_flag updated Y)
·        wsh_delivery_details (DELIVERY_DETAIL_ID is assigned here, released_status ‘R’ ready to release, LINE_ID comes as SOURCE_LINE_ID)
·        wsh_delivery_assignments (DELIVERY_ASSIGNMENT_ID is assigned for DELIVERY_DETAIL_ID present in wsh_delivery_details, DELIVERY_ID remains blank till this stage)
*In shipping transaction form order status remains "Ready to Release".
At the same time, Demand interface program runs in background And insert into inventory tables mtl_demand, here LINE_ID come as a reference in DEMAND_SOURCE_LINE
3. Reservation
This step is required for doing reservations SCHEDULE ORDER PROGRAM runs in the background and quantities are reserved. Once this program get successfully get completed, the mtl_demand and mtl_reservations table get updated. LINE_ID gets updated in DEMAND_SOURCE_LINE_ID in both the tables.
4. Pick Release
Pick Release is the process of putting reservation on on-hand quantity available in the inventory and pick them for particular sales order.
Pick release can be done from 'Release Sales Order' form or 'Pick release SRS' program can be scheduled in background. In both of these cases all lines of the order gets pick released depending on the Picking rule used. If specific line/s needs to be pick release it can be done from 'Shipping Transaction form. For this case Pick Release is done from 'Release Sales Order' form with Pick Confirm=NO.
Once pick release is done these are the tables get affected:
·        If step 3 is not done then MTL_RESERVATIONS gets updated now.
·        wsh_new_deliveries (one record gets inserted with SOURCE_HEADER_ID= order header ID, status_code=OP =>open)
·        wsh_delivery_assignments (DELIVERY_ID gets assigned which comes from wsh_new_deliveries)
·        wsh_delivery_details (released_status ‘S’ ‘submitted for release’)
·        MTL_TXN_REQUEST_HEADERS
·        MTL_TXN_REQUEST_LINES (LINE_ID goes as TXN_SOURCE_LINE_ID)
·        (move order tables. Here request is generated to move item from Source (RM or FG) sub-inventory to staging sub-inventory)
·        Mtl_material_transactions_temp (link to above tables through move_order_header_id/line_id, this table holds the record temporally)
·        MTL_SERIAL_NUMBERS_TEMP (if item is serial controlled at receipt then record goes in this table)
·        MTL_SERIAL_NUMBERS (enter value in GROUP_MARK_ID )
*In shipping transaction form order status remains "Released to Warehouse" and all the material still remains in source sub-inventory. We need to do Move Order Transaction for this order. Till this no material transaction has been posted to MTL_MATERIAL_TRANSACTIONS
5.Pick Confirm/ Move Order Transaction
Items are transferred from source sub-inventory to staging Sub-inventory. Here material transaction occurs.
Order line status becomes 'Picked' on Sales Order and 'Staged/Pick Confirmed' on Shipping Transaction Form.
·        MTL_MATERIAL_TRANSACTIONS_TEMP (Record gets deleted from here and gets posted to MTL_MATERIAL_TRANSACTIONS)
·        oe_order_lines_all (flow_status_code ‘PICKED’ )
·        MTL_MATERIAL_TRANSACTIONS (LINE_ID goes as TXN_SOURCE_LINE_ID)
·        mtl_transaction_accounts
·        wsh_delivery_details (released_status becomes ‘Y’ => ‘Released’ )
·        wsh_delivery_assignments
·        MTL_ONHAND_QUANTITIES
·        MTL_SERIAL_NUMBERS_TEMP (record gets inserted after putting details for the item which are serial controlled at 'Sales order issue')
·        MTL_SERIAL_NUMBERS (record gets inserted after putting details for the item which are serial controlled at 'Sales order issue')
* This step can be eliminated if we set Pick Confirm=YES at the time of Pick Release

6.Ship Confirm
Here ship confirm interface program runs in background. Data removed from wsh_new_deliveries.
 
The items on the delivery gets shipped to customer at this stage.
·        oe_order_lines_all (flow_status_code ‘shipped’)
·        wsh_delivery_details (released_status ‘C’ ‘Shipped’, SERIAL_NUMBER if quantity is ONE)
·        WSH_SERIAL_NUMBERS (records gets inserted with the DELIVERY_DETAIL_ID reference, only in case of shipped quantity is two or more)
·        mtl_transaction_interface
·        mtl_material_TRANSACTIONS (linked through Transaction source header id)
·        mtl_transaction_accounts
·        Data deleted from mtl_demand, MTL_reservations
·        Item deducted from MTL_ONHAND_QUANTITIES
·        MTL_SERIAL_NUMBERS_TEMP (records gets deleted from this table)
·        MTL_SERIAL_NUMBERS (Serial number stauts gets updated CURRENT_STATUS=4 , 'Issued out of store')
7.Enter Invoice
After shipping the order the order lines gets eligible to get transfered to RA_INTERFACE_LINES_ALL. Workflow background engine picks those records and post it to RA_INTERFACE_LINES_ALL. This is also called Receivables interface, that mean information moved to accounting area for invoicing details. Invoicing workflow activity transfers shipped item information to Oracle Receivables. At the same time records also goes in the table RA_INTERFACE_SALESCREDITS_ALL which hold details of sales credit for the particular order.
ra_interface_lines_all (interface table into which the data is transferred from order management) Then Autoinvoice program imports data from this table which get affected into this stage are receivables base table. At the same time records goes in
ra_customer_trx_all (cust_trx_id is primary key to link it to trx_lines table and trx_number is the invoice number)
ra_customer_trx_lines_all (line_attribute_1 and line_attribute_6 are linked to order number and line_id of the orders)
8.Complete Line
In this stage order line level table get updated with Flow status and open flag.
oe_order_lines_all (flow_status_code ‘shipped’, open_flag “N”)
9.Close Order
This is last step of Order Processing. In this stage only oe_order_lines_all table get updated. These are the table get affected in this step.

oe_order_lines_all (flow_status_code ‘closed’, open_flag “N”)
oe_order_HEADERS_all


Script to generate the FND Load Script


CREATE OR REPLACE VIEW XX_GENERATE_FND_SCRIPTC_V (owner
                                        , object_name
                                        , object_description
                                        , last_update_date
                                        , object_type
                                        , SOURCE
                                        , download_fnd_script
                                        , upload_fnd_script
                                         )
AS
   ---------------------------------------------------
   --- ALL_OBJECTS
   ---------------------------------------------------
   SELECT   owner
          , object_name
          , object_type || ' ' || owner || '.' || object_name object_description
          , last_ddl_time last_update_date
          , object_type
          , 'ALL_OBJECTS' SOURCE
          , 'sqlplus apps/$PASSWORD @admin/sql/' || LOWER (REPLACE (object_type, ' ', '_')) || ' ' || object_name download
          , 'sqlplus apps/$PASSWORD @admin/sql/' || object_name || '.sql' upload
       FROM all_objects
   UNION ALL
   ---------------------------------------------------
   --- PROGRAM
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , fcp.concurrent_program_name
          , fcpt.user_concurrent_program_name
          , fcp.last_update_date
          , 'PROGRAM'
          , 'FND_CONCURRENT_PROGRAMS'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afcpprog.lct'
            || fcp.concurrent_program_name
            || '_CP.ldt PROGRAM APPLICATION_SHORT_NAME="'
            || fa.application_short_name
            || '" CONCURRENT_PROGRAM_NAME="'
            || fcp.concurrent_program_name
            || '"' download
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afcpprog.lct'
            || fcp.concurrent_program_name
            || '_CP.ldt' upload
       FROM fnd_concurrent_programs fcp
          , fnd_concurrent_programs_tl fcpt
          , fnd_application fa
      WHERE fcpt.concurrent_program_id = fcp.concurrent_program_id
        AND fcpt.LANGUAGE = 'US'
        AND fa.application_id = fcp.application_id
   UNION ALL
   ---------------------------------------------------
   --- FORM
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , ff.form_name
          , fft.user_form_name
          , ff.last_update_date
          , 'FORM'
          , 'FND_FORM'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afsload.lct '
            || ff.form_name
            || '_FRM.ldt FORM APPLICATION_SHORT_NAME="'
            || fa.application_short_name
            || '" FORM_NAME="'
            || ff.form_name
            || '"' download
          , 'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afsload.lct ' || ff.form_name || '_FRM.ldt' upload
       FROM fnd_form ff
          , fnd_form_tl fft
          , fnd_application fa
      WHERE fft.form_id = ff.form_id
        AND fft.LANGUAGE = 'US'
        AND fa.application_id = ff.application_id
   UNION ALL
   ---------------------------------------------------
   --- EXECUTABLES TYPES
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , fe.execution_file_name
          , fet.user_executable_name
          , fe.last_update_date
          ,    'EXECUTABLE '
            || DECODE (fe.execution_method_code
                     , 'H', 'HOST'
                     , 'S', 'IMMEDIATE'
                     , 'J', 'JAVA STORED PROC'
                     , 'K', 'JAVA CONC PROG'
                     , 'M', 'MULTI LANG FUNC'
                     , 'I', 'PL/SQL'
                     , 'B', 'REQ SET STAGE'
                     , 'A', 'SPAWNED'
                     , 'P', 'REPORT'
                     , 'Q', 'SQL*PLUS'
                     , 'L', 'SQL*LOADER'
                     , 'E', 'PERL'
                     , '*' || fe.execution_method_code || ' ' || execution_file_name
                      )
          , 'FND_EXECUTABLES'
          , '' download
          , '' upload
       FROM fnd_executables fe
          , fnd_executables_tl fet
          , fnd_application fa
      WHERE fet.executable_id = fe.executable_id
        AND fet.LANGUAGE = 'US'
        AND fa.application_id = fe.application_id
   UNION ALL
   ---------------------------------------------------
   --- EXECUTABLE
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , fe.executable_name
          , fet.user_executable_name
          , fe.last_update_date
          , 'EXECUTABLE'
          , 'FND_EXECUTABLES'
          , '' download
          , '' upload
       FROM fnd_executables fe
          , fnd_executables_tl fet
          , fnd_application fa
      WHERE fet.executable_id = fe.executable_id
        AND fet.LANGUAGE = 'US'
        AND fa.application_id = fe.application_id
   UNION ALL
   ---------------------------------------------------
   --- WORKFLOW
   ---------------------------------------------------
   SELECT   'APPS'
          , wit.NAME
          , witl.display_name
          , wfa.last_update_date
          , 'WORKFLOW'
          , 'WF_ITEM_TYPES'
          ,    'WFLOAD apps/$PASSWORD 0 Y DOWNLOAD wf/'
            || wit.NAME
            || '_'
            || TO_CHAR (wfa.last_update_date, 'ddmonyyyy')
            || '.wft '
            || wit.NAME download
          , 'WFLOAD apps/$PASSWORD 0 Y UPLOAD wf/' || wit.NAME || '_' || TO_CHAR (wfa.last_update_date, 'ddmonyyyy')
            || '.wft ' upload
       FROM (SELECT   wpa.activity_item_type
                    , MAX (wfa.begin_date) last_update_date
                 FROM wf_process_activities wpa
                    , wf_activities wfa
                WHERE wpa.activity_item_type = wfa.item_type
                  AND wpa.activity_name = wfa.NAME
                  AND wfa.VERSION = (SELECT MAX (VERSION)
                                       FROM wf_activities wfa1
                                      WHERE wpa.activity_item_type = wfa1.item_type
                                        AND wpa.activity_name = wfa1.NAME)
             GROUP BY wpa.activity_item_type) wfa
          , wf_item_types wit
          , wf_item_types_tl witl
      WHERE witl.NAME = wit.NAME
        AND witl.LANGUAGE = 'US'
        AND wfa.activity_item_type(+) = wit.NAME
   UNION ALL
   ---------------------------------------------------
   --- MENU
   ---------------------------------------------------
   SELECT   'APPS'
          , fm.menu_name
          , fmt.user_menu_name
          , fm.last_update_date
          , 'MENU'
          , 'FND_MENUS'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afsload.lct '
            || 'fndload/'
            || REPLACE (fm.menu_name, ' ', '_')
            || '_fm.ldt '
            || 'MENU MENU_NAME="'
            || fm.menu_name
            || '"' download
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afsload.lct '
            || 'fndload/'
            || REPLACE (fm.menu_name, ' ', '_')
            || '.ldt ' upload
       FROM fnd_menus fm
          , fnd_menus_tl fmt
      WHERE fmt.menu_id = fm.menu_id
        AND fmt.LANGUAGE = 'US'
   UNION ALL
   ---------------------------------------------------
   --- MENU ENTRY
   ---------------------------------------------------
   SELECT   'APPS'
          , m2.menu_name || '/' || u.function_name || m.menu_name
          , e.entry_sequence || ' ' || u.user_function_name || m.user_menu_name
          , e.last_update_date
          , 'MENU ENTRY'
          , 'FND_MENU_ENTRIES'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afsload.lct '
            || 'fndload/'
            || REPLACE (m2.menu_name, ' ', '_')
            || '_'
            || REPLACE (u.function_name, ' ', '_')
            || '_'
            || REPLACE (m.menu_name, ' ', '_')
            || '.ldt '
            || 'MENU PARENT_MENU_NAME="'
            || m2.menu_name
            || DECODE (u.function_name, NULL, '', '" FUNCTION_NAME="' || u.function_name || '"')
            || DECODE (m.menu_name, NULL, '', '" SUB_MENU_NAME="' || m.menu_name || '"') download
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afsload.lct '
            || 'fndload/'
            || REPLACE (m2.menu_name, ' ', '_')
            || '_'
            || REPLACE (u.function_name, ' ', '_')
            || '_'
            || REPLACE (m.menu_name, ' ', '_')
            || '_fme.ldt ' upload
       FROM fnd_menu_entries_vl e
          , fnd_menus_vl m
          , fnd_menus_vl m2
          , fnd_form_functions_vl u
      WHERE e.function_id = u.function_id(+)
        AND e.sub_menu_id = m.menu_id(+)
        AND e.menu_id = m2.menu_id
   UNION ALL
   ---------------------------------------------------
   --- LOOKUP
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , flt.lookup_type
          , fltt.meaning
          , flt.last_update_date
          , 'LOOKUP'
          , 'FND_LOOKUP_TYPES'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/aflvmlu.lct '
            || 'fndload/'
            || REPLACE (flt.lookup_type, ' ', '_')
            || '_flt.ldt '
            || 'FND_LOOKUP_TYPE APPLICATION_SHORT_NAME="'
            || fa.application_short_name
            || '" '
            || 'LOOKUP_TYPE="'
            || flt.lookup_type
            || '"' download
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/aflvmlu.lct '
            || 'fndload/'
            || REPLACE (flt.lookup_type, ' ', '_')
            || '_flt.ldt ' upload
       FROM fnd_application fa
          , fnd_lookup_types flt
          , fnd_lookup_types_tl fltt
      WHERE fltt.lookup_type = flt.lookup_type
        AND fltt.LANGUAGE = 'US'
        AND fa.application_id = flt.application_id
   UNION ALL
   ---------------------------------------------------
   --- FLEXVALUES
   ---------------------------------------------------
   SELECT   'APPS'
          , ffvs.flex_value_set_name
          , ffvs.description
          , ffvs.last_update_date
          , 'FLEXVALUE'
          , 'FND_FLEX_VALUE_SETS'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afffload.lct '
            || 'fndload/'
            || REPLACE (ffvs.flex_value_set_name, ' ', '_')
            || '_ffvs.ldt '
            || 'VALUE_SET FLEX_VALUE_SET_NAME="'
            || flex_value_set_name
            || '"' download
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afffload.lct '
            || 'fndload/'
            || REPLACE (ffvs.flex_value_set_name, ' ', '_')
            || '_ffvs.ldt ' upload
       FROM fnd_flex_value_sets ffvs
   UNION ALL
   ---------------------------------------------------
   --- PERSONALIZATION
   ---------------------------------------------------
   SELECT   'APPS'
          , form_name
          , function_name
          , MAX (last_update_date)
          , 'PERSONALIZATION'
          , 'FND_FORM_CUSTOM_RULES'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/affrmcus.lct '
            || 'fndload/'
            || REPLACE (form_name, ' ', '_')
            || '_'
            || REPLACE (function_name, ' ', '_')
            || '_ffcr.ldt FND_FORM_CUSTOM_RULES FORM_NAME="'
            || form_name
            || '" '
            || 'FUNCTION_NAME="'
            || function_name
            || '"' download
          , 'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/affrmcus.lct ' || form_name || '_ffcr.ldt' upload
       FROM fnd_form_custom_rules
   GROUP BY form_name
          , function_name
   UNION ALL
   ---------------------------------------------------
   --- PROFILE
   ---------------------------------------------------
   SELECT   fa.application_short_name
          , fpo.profile_option_name
          , user_profile_option_name
          , fpo.last_update_date
          , 'PROFILE'
          , 'FND_PROFILE_OPTIONS_VL'
          ,    'FNDLOAD APPS/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afscprof.lct '
            || 'fndload/'
            || fpo.profile_option_name
            || '_fpo.ldt '
            || 'PROFILE FND_PROFILE_OPTION_VALUES PROFILE_NAME="'
            || fpo.profile_option_name
            || '" APPLICATION_SHORT_NAME="'
            || fa.application_short_name
            || '"'
          ,    'FNDLOAD APPS/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afscprof.lct '
            || 'fndload/'
            || fpo.profile_option_name
            || '_fpo.ldt '
       FROM fnd_profile_options_vl fpo
          , fnd_application fa
      WHERE fpo.application_id = fa.application_id
   UNION ALL
   ---------------------------------------------------
   --- REQUEST GROUPS
   ---------------------------------------------------
   SELECT   a.application_short_name
          , v.request_group_code
          , v.request_group_name
          , v.last_update_date
          , 'REQUEST GROUP'
          , 'FND_REQUEST_GROUPS'
          ,    'FNDLOAD APPS/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afcpreqg.lct '
            || 'fndload/'
            || v.request_group_code
            || '_rg.ldt '
            || 'REQUEST_GROUP REQUEST_GROUP_NAME="'
            || v.request_group_code
            || '"'
          ,    'FNDLOAD APPS/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afcpreqg.lct '
            || 'fndload/'
            || v.request_group_code
            || '_rg.ldt '
       FROM fnd_request_groups v
          , fnd_application a
      WHERE 1 = 1
        AND a.application_id = v.application_id
   UNION ALL
   ---------------------------------------------------
   --- REQUEST GROUP UNITS
   ---------------------------------------------------
   SELECT   va.application_short_name
          , g.request_group_name
          , DECODE (v.request_unit_type, 'P', p.concurrent_program_name, 'S', s.request_set_name)
          , v.last_update_date
          , 'REQUEST GROUP UNIT'
          , 'FND_REQUEST_GROUP_UNITS'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afcpreqg.lct'
            || REPLACE (   g.request_group_name
                        || '_'
                        || DECODE (v.request_unit_type, 'P', p.concurrent_program_name, 'S', s.request_set_name)
                      , ' '
                      , '_'
                       )
            || '_frgu.ldt '
            || 'REQUEST_GROUP REQUEST_GROUP_NAME="'
            || g.request_group_name
            || '" UNIT_NAME="'
            || DECODE (v.request_unit_type, 'P', p.concurrent_program_name, 'S', s.request_set_name)
            || '"'
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afcpreqg.lct'
            || REPLACE (   g.request_group_name
                        || '_'
                        || DECODE (v.request_unit_type, 'P', p.concurrent_program_name, 'S', s.request_set_name)
                      , ' '
                      , '_'
                       )
            || '_frgu.ldt '
       FROM fnd_application va
          , fnd_application a
          , fnd_concurrent_programs p
          , fnd_request_sets s
          , fnd_request_group_units v
          , fnd_request_groups g
      WHERE 1 = 1
        AND g.application_id = va.application_id
        AND v.application_id = g.application_id
        AND v.request_group_id = g.request_group_id
        AND a.application_id = v.unit_application_id
        AND v.unit_application_id = p.application_id(+)
        AND v.unit_application_id = s.application_id(+)
        AND (   (    v.request_unit_type = 'P'
                 AND v.request_unit_id = p.concurrent_program_id)
             OR (    v.request_unit_type = 'S'
                 AND v.request_unit_id = s.request_set_id)
             OR v.request_unit_type NOT IN ('S', 'P')
            )
        AND DECODE (v.request_unit_type, 'P', v.request_unit_id, NULL) = p.concurrent_program_id(+)
        AND DECODE (v.request_unit_type, 'S', v.request_unit_id, NULL) = s.request_set_id(+)
   UNION ALL   -------------------------------------------------------------- REQUEST GROUP UNITS
   SELECT   'APPS' owner
          , plsql_type object_name
          , plsql_name object_description
          , last_update_date
          , 'WEB PLSQL' object_type
          , 'FND_ENABLED_PLSQL'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afscursp.lct'
            || plsql_type
            || '_'
            || plsql_name
            || '_fep.ldt '
            || 'FND_ENABLED_PLSQL PLSQL_TYPE="'
            || plsql_type
            || '" PLSQL_NAME="'
            || plsql_name
            || '"'
          ,    'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afscursp.lct'
            || plsql_type
            || '_'
            || plsql_name
            || '_fep.ldt '
       FROM fnd_enabled_plsql
   UNION ALL
   ---------------------------------------------------
   --- ALERT
   ---------------------------------------------------
   SELECT   a1.application_short_name
          , v.alert_name
          , v.description
          , v.last_update_date
          , 'ALERT'
          , 'ALR_ALERTS'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $ALR_TOP/patch/115/import/alr.lct'
            || v.alert_name
            || '_alr.ldt '
            || 'ALR_ALERTS APPLICATION_SHORT_NAME="'
            || a1.application_short_name
            || '" ALERT_NAME="'
            || v.alert_name
            || '"'
          , 'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $ALR_TOP/patch/115/import/alr.lct' || v.alert_name || '_alr.ldt '
       FROM fnd_application a1
          , alr_alerts v
          , fnd_application a2
      WHERE a1.application_id = v.application_id
        AND v.table_application_id = a2.application_id(+)
   UNION ALL
   ---------------------------------------------------
   --- USER
   ---------------------------------------------------
   SELECT   'APPS'
          , user_name
          , description
          , last_update_date
          , 'USER'
          , 'FND_USER'
          ,    'FNDLOAD apps/$PASSWORD 0 Y DOWNLOAD $FND_TOP/patch/115/import/afscursp.lct'
            || user_name
            || '_user.ldt FND_USER USER_NAME="'
            || user_name
            || '"'
          , 'FNDLOAD apps/$PASSWORD 0 Y UPLOAD $FND_TOP/patch/115/import/afscursp.lct ' || user_name || '_user.ldt'
       FROM fnd_user
   ORDER BY 1
          , 2
          , 3;

Saturday, September 7, 2013

Script To Generate SQL*Loader Control File (Doc ID 1019523.6)


SELECT    'LOAD DATA'
       || CHR (10)
       || 'INFILE '''
       || LOWER (table_name)
       || '.dat'''
       || CHR (10)
       || '<APPEND/REPLACE/TRUNCATE>'
       || CHR (10)
       || 'INTO TABLE '
       || table_name
       || CHR (10)
       || 'FIELDS TERMINATED BY '','''
       || CHR (10)
       || 'TRAILING NULLCOLS'
       || CHR (10)
       || '('
  FROM all_tables
 WHERE table_name = UPPER ('&1');

SELECT      DECODE (ROWNUM, 1, ' ', ' , ')
         || RPAD (column_name, 33, ' ')
         || DECODE (data_type
                  , 'VARCHAR2', 'CHAR NULLIF (' || column_name || '=BLANKS)'
                  , 'FLOAT', 'DECIMAL EXTERNAL NULLIF(' || column_name || '=BLANKS)'
                  , 'NUMBER', DECODE (data_precision
                                    , 0, 'INTEGER EXTERNAL NULLIF (' || column_name || '=BLANKS)'
                                    , DECODE (data_scale
                                            , 0, 'INTEGER EXTERNAL NULLIF (' || column_name || '=BLANKS)'
                                            , 'DECIMAL EXTERNAL NULLIF (' || column_name || '=BLANKS)'
                                             )
                                     )
                  , 'DATE', 'DATE "MM/DD/YY" NULLIF (' || column_name || '=BLANKS)'
                  , NULL
                   )
    FROM user_tab_columns
   WHERE table_name = UPPER ('&1')
ORDER BY column_id;

SELECT ')'
  FROM SYS.DUAL;

Friday, August 16, 2013

Submit Concurrent Program through DB Trigger

CREATE OR REPLACE TRIGGER "APPS"."XX_MERGE_BATCH_TRG"
   AFTER INSERT
   ON xx_merge_batch
   FOR EACH ROW
   WHEN (NEW.batch_status = 'PENDING')
DECLARE
   req_id                                            NUMBER;
   RESULT                                            BOOLEAN;
BEGIN
   RESULT                                                   := fnd_request.set_mode (TRUE);
   req_id                                                   :=
      apps.fnd_request.submit_request ('<CONC_PROG_APPL>'
                                     , '<CONC_PROG_SHORT_NAME>'
                                     , ''
                                     , TO_CHAR (SYSDATE + 30 / 86400, 'DD-MON-YYYY HH24:MI:SS')
                                     , FALSE
                                     , :NEW.batch_id
                                      );

   IF req_id = 0
   THEN
            raise_application_error ( -20160, apps.fnd_message.get);
   END IF;
EXCEPTION
   WHEN OTHERS
   THEN
      NULL;
END;
/