Purge plan

The purge plan process deletes the plan results from SCV plan tables. This process is implemented using the PURGE_PLAN program.

The PURGE_PLAN program considers these input parameters:

PLAN_TABLE_NAME
The name of the plan table to be deleted.
Note: If this parameter is specified:
  • An exisitng entry must be available in the SZ_REG_TABLE table where table_area is set to Core and plan_table_flag is set to True. An error message is logged, and the execution is stopped if the Core plan table is not available with the specified <PLAN_TABLE_NAME> value in the SZ_REG_TABLE table.
  • The specified table must be a header plan table. An error is logged, and the execution is stopped if the specified table is a child plan table (that is, an FK-type constraint exists on <PLAN_TABLE_NAME> where parent_reference_flag = ‘Y’).

These are the other optional input parameters that can be used as conditions for deletion:

  • CYCLE_PERIOD
  • SCENARIO
  • PLAN_NAME
  • PLAN_CATEGORY
  • PLAN_TYPE
  • PLAN_VERSION
  • PLAN_SUBTYPE
  • PLAN_VALUE_STATUS
  • PLAN_VALUE_TYPE
  • EXPORT_STATUS
  • SCP_ORDER_STATUS
  • PERIOD_START
  • PERIOD_END
  • SOURCE

The PURGE_PLAN program deletes plan results in the specified <PLAN_TABLE_NAME> as follows:

  • Logs new task log record for the PLAN_TABLE_NAME parameter. This uses the task_name format: <PLAN_TABLE_NAME> as the table name in the task log. For example, SC_ITEM.
  • Validates the input parameters as follows:
    • Verifies if the columns corresponding to each specified input parameter are available in the specified <PLAN_TABLE_NAME>.
    • Logs a Warning message for each input parameter or column that is not available in the table.
  • Creates an SQL DELETE statement on the <PLAN_TABLE_NAME> using the input parameters created as follows:
    1. Prepares the base purge condition  
       <condition> = WHERE 1=1  
    
    2. Appends a condition for <SOURCE>  
       <condition> = <condition> + AND source = <SOURCE>  
    
    3. If specified, appends a condition for <CYCLE_PERIOD>  
       <condition> = <condition> + AND cycle_period_id = <CYCLE_PERIOD>  
    
    4. If specified, appends a condition for <SCENARIO>  
       <condition> = <condition> + AND scenario_id = <SCENARIO>  
    
    5. If specified, appends a condition for <PLAN_NAME>  
       <condition> = <condition> + AND plan_name = <PLAN_NAME>  
    
    6. If specified, appends a condition for <PLAN_CATEGORY>  
       <condition> = <condition> + AND plan_category = <PLAN_CATEGORY>  
    
    7. If specified, appends a condition for <PLAN_TYPE>  
       <condition> = <condition> + AND plan_type = <PLAN_TYPE>  
    
    8. If specified, appends a condition for <PLAN_VERSION>  
       <condition> = <condition> + AND plan_version = <PLAN_VERSION>  
    
    9. If specified, appends a condition for <PLAN_SUBTYPE>  
       <condition> = <condition> + AND plan_subtype = <PLAN_SUBTYPE>  
    
    10. If specified, appends a condition for <PLAN_VALUE_STATUS>  
       <condition> = <condition> + AND plan_value_status = <PLAN_VALUE_STATUS>  
    
    11. If specified, appends a condition for <PLAN_VALUE_TYPE>  
       <condition> = <condition> + AND plan_value_type = <PLAN_VALUE_TYPE>  
    
    12. If specified, appends a condition for <EXPORT_STATUS>  
       <condition> = <condition> + AND export_status = <EXPORT_STATUS>  
    
    13. If specified, appends a condition for <SCP_ORDER_STATUS>  
       <condition> = <condition> + AND scp_order_status = <SCP_ORDER_STATUS>  
    
    14. Find the Export Horizon Key column defined on <PLAN_TABLE_NAME>  
       <EK constraint> = Entry in SZ_REG_CONSTRAINT where table_name = <PLAN_TABLE_NAME> and type = 'EK'  
       <EK constraint column> = Entry in SZ_REG_CONSTRAINT_COLUMN where constraint_id = <EK constraint> and column_sequence = 1  
    
    15. If specified, appends a condition for <PERIOD_START>  
       If no EK constraints are defined on <PLAN_TABLE_NAME> or no constraint columns are found, then log error and return.  
    
       Else:      
       <condition> = <condition> + AND <EK constraint column> >= <PERIOD_START>  
    
    16. If specified, appends a condition for <PERIOD_END>  
       If no EK constraints are defined on <PLAN_TABLE_NAME> or no constraint columns are found, then log error and return.  
    
       Else:      
       <condition> = <condition> + AND <EK constraint column> <= <PERIOD_END>  
    
    17. If <PLAN_TABLE_NAME> has child tables, then prepares and executes delete statements to purge each child table.  
       If <child table> has an FK-type constraint where parent_reference_flag = "Y" and where the referenced constraint is defined on <PLAN_TABLE_NAME>, then <PLAN_TABLE_NAME> is the parent of <child table>. Records in <child table> must be purged first.  
    
       For each <child table>:  
       a. Purge profile records  
          DELETE FROM <child table>_P WHERE id IN  
            (SELECT id FROM <child table> WHERE EXISTS  
                (SELECT 'X'  
                 FROM <PLAN_TABLE_NAME>  
                 WHERE <child table>.<FK-column(n)> = <PLAN_TABLE_NAME>.<FK-column(n)>  
                 AND <condition>  
                )  
            )  
       b. Purge hierarchy records  
          DELETE FROM <child table>_H WHERE id IN  
            (SELECT id FROM <child table> WHERE EXISTS  
                (SELECT 'X'  
                 FROM <PLAN_TABLE_NAME>  
                 WHERE <child table>.<FK-column(n)> = <PLAN_TABLE_NAME>.<FK-column(n)>  
                 AND <condition>  
                )  
            )  
       c. Purge child table  
          DELETE FROM <child table> WHERE EXISTS  
            (SELECT 'X'  
             FROM <PLAN_TABLE_NAME>  
             WHERE <child table>.<FK-column(n)> = <PLAN_TABLE_NAME>.<FK-column(n)>  
             AND <condition>  
            )  
    18. Prepares and executes delete statements to purge <PLAN_TABLE_NAME>.  
       a. Purge profile records  
          DELETE FROM <PLAN_TABLE_NAME>_P WHERE id IN (SELECT id FROM <PLAN_TABLE_NAME> <condition>)  
       b. Purge hierarchy records  
          DELETE FROM <PLAN_TABLE_NAME>_H WHERE id IN (SELECT id FROM <PLAN_TABLE_NAME> <condition>)  
       c. Purge <PLAN_TABLE_NAME>  
          DELETE FROM <PLAN_TABLE_NAME> <condition>  
    
  • Commits the changes if the SQL statements for <child table> and <PLAN_TABLE_NAME> are executed successfully.
  • Completes the task log record with the actual status.

This table lists the default values for the input parameters of the PURGE_PLAN program:

Parameter Default value Description Possible values
TABLE_NAME Program scope parameter: Table Name. Must be a valid plan table name in SCV Table Registry.
SOURCE Program scope parameter: Source.
CYCLE_PERIOD Program scope parameter: Cycle Period.
SCENARIO Program scope parameter: Scenario.
PLAN_TYPE Program scope parameter: Plan Type.
PLAN_VERSION Program scope parameter: Plan Version.
PERIOD_START Program scope parameter: Period Start.
PERIOD_END Program scope parameter: Period End.