1
0

merge_config_metadata.db2 930 B

1234567891011121314151617181920212223242526272829303132
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_CONFIG_METADATA(ACTIVE, XML)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_CONFIG_METADATA (
  7. IN ACTIVE SMALLINT,
  8. IN XML CLOB,
  9. IN MODIFIED_BY VARCHAR(64) DEFAULT CURRENT USER,
  10. IN TIMESTAMP TIMESTAMP DEFAULT CURRENT TIMESTAMP
  11. )
  12. BEGIN
  13. DECLARE SQL_STMT VARCHAR(4000);
  14. SET SQL_STMT = 'MERGE INTO MWCONFIG.CONFIG_METADATA AS T ' ||
  15. 'USING (VALUES (' || ACTIVE || ')) ' ||
  16. 'AS S (ACTIVE) ' ||
  17. 'ON (T.ACTIVE = S.ACTIVE) ' ||
  18. 'WHEN MATCHED THEN ' ||
  19. 'UPDATE SET
  20. T.XML = ''' || XML || ''',
  21. T.MODIFIED_BY = ''' || MODIFIED_BY || ''',
  22. T.TIMESTAMP = ''' || TIMESTAMP || ''' ' ||
  23. 'WHEN NOT MATCHED THEN ' ||
  24. 'INSERT (ACTIVE, XML, MODIFIED_BY, TIMESTAMP) ' ||
  25. 'VALUES (' || ACTIVE || ', ''' || XML || ''', ''' || MODIFIED_BY || ''', ''' || TIMESTAMP || ''')';
  26. PREPARE STMT FROM SQL_STMT;
  27. EXECUTE STMT;
  28. END
  29. @