- Bump package version to 3.6.3 and update build date. - Add new parameters: pIsArchiveEnabled, pIsKeepInTrash, pArchivalStrategy, pMinimumAgeMonths to ADD_SOURCE_FILE_CONFIG. - Include pIsWorkflowSuccessRequired parameter to control workflow success requirement for archival. - Update version history to reflect changes. feat(A_SOURCE_FILE_CONFIG): Modify table structure to include new archival control flags - Add IS_WORKFLOW_SUCCESS_REQUIRED column to A_SOURCE_FILE_CONFIG for workflow bypass functionality. - Update constraints and comments for new columns. - Ensure backward compatibility with default values. fix(A_TABLE_STAT, A_TABLE_STAT_HIST): Extend table structures to accommodate new workflow success tracking - Add IS_WORKFLOW_SUCCESS_REQUIRED column to both A_TABLE_STAT and A_TABLE_STAT_HIST. - Update comments to clarify the purpose of new columns. docs(FILE_ARCHIVER_Guide): Revise documentation to reflect new archival features and configurations - Document new IS_WORKFLOW_SUCCESS_REQUIRED flag and its implications for archival processes. - Update examples and configurations to align with recent changes in the database schema. - Ensure clarity on archival strategies and their configurations.
129 lines
5.7 KiB
SQL
129 lines
5.7 KiB
SQL
-- ============================================================================
|
|
-- MARS-1409 Master Rollback Script
|
|
-- ============================================================================
|
|
-- Author: Grzegorz Michalski
|
|
-- Purpose: Rollback A_WORKFLOW_HISTORY_KEY column changes from A_SOURCE_FILE_RECEIVED
|
|
-- Target Schema: CT_MRDS
|
|
-- Estimated Time: 1-2 minutes
|
|
-- Prerequisites: Backup of current FILE_MANAGER package, ADMIN privileges
|
|
-- ============================================================================
|
|
|
|
SET SERVEROUTPUT ON SIZE UNLIMITED
|
|
SET VERIFY OFF
|
|
SET FEEDBACK ON
|
|
SET ECHO OFF
|
|
|
|
-- Create log directory if it doesn't exist
|
|
host mkdir log 2>nul
|
|
|
|
-- Generate dynamic SPOOL filename with timestamp
|
|
var filename VARCHAR2(100)
|
|
BEGIN
|
|
:filename := 'log/ROLLBACK_MARS_1409_' || SYS_CONTEXT('USERENV', 'CON_NAME') || '_' || TO_CHAR(SYSDATE,'YYYYMMDD_HH24MISS') || '.log';
|
|
END;
|
|
/
|
|
column filename new_value _filename
|
|
select :filename filename from dual;
|
|
spool &_filename
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT MARS-1409 Rollback Starting
|
|
PROMPT ============================================================================
|
|
PROMPT Package: CT_MRDS.FILE_MANAGER
|
|
PROMPT Change: Remove A_WORKFLOW_HISTORY_KEY column and restore previous version
|
|
PROMPT Steps: 11 (Restore FILE_ARCHIVER, Restore FILE_MANAGER, Restore ENV_MANAGER, Restore trigger, Drop ARCHIVAL_STRATEGY/ARCH_MINIMUM_AGE_MONTHS/IS_WORKFLOW_SUCCESS_REQUIRED/WORKFLOW_SUCCESS_* columns, Drop column, Verify)
|
|
PROMPT Timestamp:
|
|
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS rollback_start FROM DUAL;
|
|
PROMPT ============================================================================
|
|
|
|
-- Confirm rollback with user
|
|
ACCEPT continue CHAR PROMPT 'Type YES to continue with rollback, or Ctrl+C to abort: '
|
|
WHENEVER SQLERROR EXIT SQL.SQLCODE
|
|
BEGIN
|
|
IF '&continue' IS NULL OR TRIM('&continue') IS NULL OR UPPER(TRIM('&continue')) != 'YES' THEN
|
|
RAISE_APPLICATION_ERROR(-20000, 'Rollback aborted by user');
|
|
END IF;
|
|
END;
|
|
/
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 1: Restore FILE_ARCHIVER package specification (previous version)
|
|
PROMPT ============================================================================
|
|
@@91_MARS_1409_rollback_CT_MRDS_FILE_ARCHIVER_SPEC.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 2: Restore FILE_ARCHIVER package body (previous version)
|
|
PROMPT ============================================================================
|
|
@@92_MARS_1409_rollback_CT_MRDS_FILE_ARCHIVER_BODY.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 3: Restore FILE_MANAGER package specification (previous version)
|
|
PROMPT ============================================================================
|
|
@@93_MARS_1409_rollback_CT_MRDS_FILE_MANAGER_SPEC.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 4: Restore FILE_MANAGER package body (previous version)
|
|
PROMPT ============================================================================
|
|
@@94_MARS_1409_rollback_CT_MRDS_FILE_MANAGER_BODY.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 5: Restore ENV_MANAGER package specification (previous version)
|
|
PROMPT ============================================================================
|
|
@@95_MARS_1409_rollback_CT_MRDS_ENV_MANAGER_SPEC.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 6: Restore ENV_MANAGER package body (previous version)
|
|
PROMPT ============================================================================
|
|
@@96_MARS_1409_rollback_CT_MRDS_ENV_MANAGER_BODY.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 7: Restore A_WORKFLOW_HISTORY trigger (previous version)
|
|
PROMPT ============================================================================
|
|
@@97_MARS_1409_rollback_CT_MRDS_A_WORKFLOW_HISTORY.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 8: Drop ARCHIVAL_STRATEGY, ARCH_MINIMUM_AGE_MONTHS, IS_WORKFLOW_SUCCESS_REQUIRED and WORKFLOW_SUCCESS_FILE_COUNT/ROW_COUNT/SIZE columns from A_TABLE_STAT and A_TABLE_STAT_HIST
|
|
PROMPT ============================================================================
|
|
@@98_MARS_1409_rollback_archival_strategy_column.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 9: Drop A_WORKFLOW_HISTORY_KEY column
|
|
PROMPT ============================================================================
|
|
@@99_MARS_1409_rollback_workflow_history_key_column.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 10: Verify rollback
|
|
PROMPT ============================================================================
|
|
@@90_MARS_1409_verify_rollback.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT STEP 11: Verify package versions
|
|
PROMPT ============================================================================
|
|
@@verify_packages_version.sql
|
|
|
|
PROMPT
|
|
PROMPT ============================================================================
|
|
PROMPT MARS-1409 Rollback Complete
|
|
PROMPT ============================================================================
|
|
PROMPT Final Status:
|
|
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS rollback_end FROM DUAL;
|
|
PROMPT
|
|
PROMPT Review the log file for detailed results: &_filename
|
|
PROMPT ============================================================================
|
|
|
|
spool off
|
|
|
|
quit;
|