1
0

merge_routing_table.db2 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_ROUTING_TABLE(ID, CODE_START, CODE_END, CHANNEL, START_DATE, END_DATE, QUEUE, STATUS, SUBCODEX, ADDITIONAL, REPLY_TO, REPLY_TO_QMGR)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_ROUTING_TABLE (
  7. IN CODE_START VARCHAR(256),
  8. IN CODE_END VARCHAR(256),
  9. IN CHANNEL VARCHAR(256),
  10. IN START_DATE TIMESTAMP,
  11. IN END_DATE TIMESTAMP,
  12. IN QUEUE VARCHAR(256),
  13. IN STATUS VARCHAR(20),
  14. IN SUBCODEX VARCHAR(256),
  15. IN ADDITIONAL INTEGER,
  16. IN REPLY_TO VARCHAR(256),
  17. IN REPLY_TO_QMGR VARCHAR(256),
  18. IN CREATE_BY VARCHAR(256) DEFAULT CURRENT USER,
  19. IN CREATE_DATE TIMESTAMP DEFAULT CURRENT TIMESTAMP,
  20. IN MODIFIED_BY VARCHAR(256) DEFAULT CURRENT USER,
  21. IN MODIFIED_DATE TIMESTAMP DEFAULT CURRENT TIMESTAMP
  22. )
  23. LANGUAGE SQL
  24. BEGIN
  25. DECLARE SQL_STMT VARCHAR(10000);
  26. SET SQL_STMT = 'MERGE INTO MWCONFIG.ROUTING_TABLE AS T ' ||
  27. 'USING (VALUES (' ||
  28. CASE WHEN CODE_START IS NOT NULL THEN '''' || CODE_START || '''' ELSE 'NULL' END || ', ' ||
  29. CASE WHEN CODE_END IS NOT NULL THEN '''' || CODE_END || '''' ELSE 'NULL' END || ', ' ||
  30. CASE WHEN CHANNEL IS NOT NULL THEN '''' || CHANNEL || '''' ELSE 'NULL' END || ', ' ||
  31. CASE WHEN START_DATE IS NOT NULL THEN '''' || START_DATE || '''' ELSE 'NULL' END || ', ' ||
  32. CASE WHEN END_DATE IS NOT NULL THEN '''' || END_DATE || '''' ELSE 'NULL' END || ', ' ||
  33. CASE WHEN QUEUE IS NOT NULL THEN '''' || QUEUE || '''' ELSE 'NULL' END || ', ' ||
  34. CASE WHEN STATUS IS NOT NULL THEN '''' || STATUS || '''' ELSE 'NULL' END || ', ' ||
  35. CASE WHEN SUBCODEX IS NOT NULL THEN '''' || SUBCODEX || '''' ELSE 'NULL' END || ', ' ||
  36. CASE WHEN ADDITIONAL IS NOT NULL THEN '''' || ADDITIONAL || '''' ELSE 'NULL' END || ', ' ||
  37. CASE WHEN REPLY_TO IS NOT NULL THEN '''' || REPLY_TO || '''' ELSE 'NULL' END || ', ' ||
  38. CASE WHEN REPLY_TO_QMGR IS NOT NULL THEN '''' || REPLY_TO_QMGR || '''' ELSE 'NULL' END || ', ' ||
  39. 'CURRENT_USER, CURRENT_TIMESTAMP)) AS S ' || '(CODE_START, CODE_END, CHANNEL, START_DATE, END_DATE, QUEUE, STATUS, SUBCODEX, ADDITIONAL, REPLY_TO, REPLY_TO_QMGR, CREATE_BY, CREATE_DATE) ' ||
  40. 'ON (T.CHANNEL = S.CHANNEL AND T.CODE_START = S.CODE_START AND T.CODE_END = S.CODE_END) ' ||
  41. 'WHEN MATCHED THEN ' ||
  42. ' UPDATE SET ' ||
  43. ' T.CODE_START = ' ||
  44. CASE WHEN CODE_START IS NOT NULL THEN '''' || CODE_START || '''' ELSE 'NULL' END || ', ' ||
  45. ' T.CODE_END = ' ||
  46. CASE WHEN CODE_END IS NOT NULL THEN '''' || CODE_END || '''' ELSE 'NULL' END || ', ' ||
  47. ' T.CHANNEL = ' ||
  48. CASE WHEN CHANNEL IS NOT NULL THEN '''' || CHANNEL || '''' ELSE 'NULL' END || ', ' ||
  49. ' T.START_DATE = ' ||
  50. CASE WHEN START_DATE IS NOT NULL THEN '''' || START_DATE || '''' ELSE 'NULL' END || ', ' ||
  51. ' T.END_DATE = ' ||
  52. CASE WHEN END_DATE IS NOT NULL THEN '''' || END_DATE || '''' ELSE 'NULL' END || ', ' ||
  53. ' T.QUEUE = ' ||
  54. CASE WHEN QUEUE IS NOT NULL THEN '''' || QUEUE || '''' ELSE 'NULL' END || ', ' ||
  55. ' T.STATUS = ' ||
  56. CASE WHEN STATUS IS NOT NULL THEN '''' || STATUS || '''' ELSE 'NULL' END || ', ' ||
  57. ' T.SUBCODEX = ' ||
  58. CASE WHEN SUBCODEX IS NOT NULL THEN '''' || SUBCODEX || '''' ELSE 'NULL' END || ', ' ||
  59. ' T.ADDITIONAL = ' ||
  60. CASE WHEN ADDITIONAL IS NOT NULL THEN '''' || ADDITIONAL || '''' ELSE 'NULL' END || ', ' ||
  61. ' T.REPLY_TO = ' ||
  62. CASE WHEN REPLY_TO IS NOT NULL THEN '''' || REPLY_TO || '''' ELSE 'NULL' END || ', ' ||
  63. ' T.REPLY_TO_QMGR = ' ||
  64. CASE WHEN REPLY_TO_QMGR IS NOT NULL THEN '''' || REPLY_TO_QMGR || '''' ELSE 'NULL' END || ', ' ||
  65. ' T.MODIFIED_BY = CURRENT_USER, T.MODIFIED_DATE = CURRENT_TIMESTAMP ' ||
  66. 'WHEN NOT MATCHED THEN ' ||
  67. ' INSERT (CODE_START, CODE_END, CHANNEL, START_DATE, END_DATE, QUEUE, STATUS, SUBCODEX, ADDITIONAL, REPLY_TO, REPLY_TO_QMGR, CREATE_BY, CREATE_DATE) ' ||
  68. ' VALUES (' ||
  69. CASE WHEN CODE_START IS NOT NULL THEN '''' || CODE_START || '''' ELSE 'NULL' END || ', ' ||
  70. CASE WHEN CODE_END IS NOT NULL THEN '''' || CODE_END || '''' ELSE 'NULL' END || ', ' ||
  71. CASE WHEN CHANNEL IS NOT NULL THEN '''' || CHANNEL || '''' ELSE 'NULL' END || ', ' ||
  72. CASE WHEN START_DATE IS NOT NULL THEN '''' || START_DATE || '''' ELSE 'NULL' END || ', ' ||
  73. CASE WHEN END_DATE IS NOT NULL THEN '''' || END_DATE || '''' ELSE 'NULL' END || ', ' ||
  74. CASE WHEN QUEUE IS NOT NULL THEN '''' || QUEUE || '''' ELSE 'NULL' END || ', ' ||
  75. CASE WHEN STATUS IS NOT NULL THEN '''' || STATUS || '''' ELSE 'NULL' END || ', ' ||
  76. CASE WHEN SUBCODEX IS NOT NULL THEN '''' || SUBCODEX || '''' ELSE 'NULL' END || ', ' ||
  77. CASE WHEN ADDITIONAL IS NOT NULL THEN '''' || ADDITIONAL || '''' ELSE 'NULL' END || ', ' ||
  78. CASE WHEN REPLY_TO IS NOT NULL THEN '''' || REPLY_TO || '''' ELSE 'NULL' END || ', ' ||
  79. CASE WHEN REPLY_TO_QMGR IS NOT NULL THEN '''' || REPLY_TO_QMGR || '''' ELSE 'NULL' END || ', ' ||
  80. 'CURRENT_USER, CURRENT_TIMESTAMP)';
  81. PREPARE STMT FROM SQL_STMT;
  82. EXECUTE STMT;
  83. END
  84. @