merge_codex.db2 1.5 KB

123456789101112131415161718192021222324252627282930313233343536
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_CODEX(ID, ALLOW_PARTIAL, XML)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_CODEX (
  7. IN ID VARCHAR(256),
  8. IN ALLOW_PARTIAL SMALLINT,
  9. IN XML CLOB
  10. )
  11. BEGIN
  12. DECLARE SQL_STMT VARCHAR(4000);
  13. SET SQL_STMT = 'MERGE INTO MWCONFIG.CODEX AS T ' ||
  14. 'USING (VALUES (''' || ID || ''', ' ||
  15. CASE WHEN ALLOW_PARTIAL IS NULL THEN 'NULL' ELSE CAST(ALLOW_PARTIAL AS VARCHAR(5)) END || ', ' ||
  16. CASE WHEN XML IS NULL THEN 'NULL' ELSE '''' || XML || '''' END || ')) AS S (ID, ALLOW_PARTIAL, XML) ' ||
  17. 'ON (T.ID = S.ID) ' ||
  18. 'WHEN MATCHED THEN ' ||
  19. 'UPDATE SET T.ALLOW_PARTIAL = ' ||
  20. CASE WHEN ALLOW_PARTIAL IS NULL THEN 'NULL' ELSE CAST(ALLOW_PARTIAL AS VARCHAR(5)) END || ',' ||
  21. ' T.XML = ' ||
  22. CASE WHEN XML IS NULL THEN 'NULL' ELSE '''' || XML || '''' END || ',' ||
  23. ' T.MODIFIED_BY = ''' || CURRENT_USER || '''' ||
  24. ', T.TIMESTAMP = ''' || CURRENT_TIMESTAMP || '''' ||
  25. ' WHEN NOT MATCHED THEN ' ||
  26. 'INSERT (ID, ALLOW_PARTIAL, XML, MODIFIED_BY, TIMESTAMP) ' ||
  27. 'VALUES (''' || ID || ''', ' ||
  28. CASE WHEN ALLOW_PARTIAL IS NULL THEN 'NULL' ELSE CAST(ALLOW_PARTIAL AS VARCHAR(5)) END || ',' ||
  29. CASE WHEN XML IS NULL THEN 'NULL' ELSE '''' || XML || '''' END || ',''' || CURRENT_USER || ''', ''' || CURRENT_TIMESTAMP || ''')';
  30. PREPARE STMT FROM SQL_STMT;
  31. EXECUTE STMT;
  32. END
  33. @