merge_parser_codex.db2 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_PARSER_CODEX(PARSER_ID, ID, CODEX_ID)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_PARSER_CODEX (
  7. IN PARSER_ID VARCHAR(256),
  8. IN ID VARCHAR(256),
  9. IN CODEX_ID VARCHAR(256),
  10. IN MODIFIED_BY VARCHAR(64) DEFAULT CURRENT_USER,
  11. IN TIMESTAMP TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  12. )
  13. LANGUAGE SQL
  14. BEGIN
  15. DECLARE SQL_STMT VARCHAR(10000);
  16. SET SQL_STMT = 'MERGE INTO MWCONFIG.PARSER_CODEX AS T ' ||
  17. 'USING (VALUES (''' || PARSER_ID || ''', ''' || ID || ''', ''' || CODEX_ID || ''', ''' || MODIFIED_BY || ''', ''' || TIMESTAMP || ''')) AS S (PARSER_ID, ID, CODEX_ID, MODIFIED_BY, TIMESTAMP) ' ||
  18. 'ON (T.PARSER_ID = S.PARSER_ID AND T.ID = S.ID) ' ||
  19. 'WHEN MATCHED THEN ' ||
  20. ' UPDATE SET ' ||
  21. ' T.CODEX_ID = S.CODEX_ID, ' ||
  22. ' T.MODIFIED_BY = S.MODIFIED_BY, ' ||
  23. ' T.TIMESTAMP = S.TIMESTAMP ' ||
  24. 'WHEN NOT MATCHED THEN ' ||
  25. ' INSERT (PARSER_ID, ID, CODEX_ID, MODIFIED_BY, TIMESTAMP) ' ||
  26. ' VALUES (S.PARSER_ID, S.ID, S.CODEX_ID, S.MODIFIED_BY, S.TIMESTAMP)';
  27. PREPARE STMT FROM SQL_STMT;
  28. EXECUTE STMT;
  29. END
  30. @