How to Quickly Append VARCHAR2 to CLOB
This is not an APEX specific issue, however it could be useful for some of your PL/SQL code
I ran into an issue today where I had to append VARCHAR2s to a CLOB many times in a loop. I first tried appending a VARCHAR2 to a CLOB: CLOB := CLOB || VARCHAR2. I noticed that this was taking a long time to run. In order to speed up the process I tried the following techniques:
- Create a "temp" CLOB (TMP_CLOB := VARCHAR2) and then appended it the clob CLOB := CLOB || CLOB
- Use the CLOB := CLOB || TO_CLOB(VARCHAR2)
- Use DBMS_LOB.append (CLOB, VARCHAR2)
All three options resulted in significant speed increases, however using the "temp" CLOB method resulted in the quickest code. Here is the test that I ran along with the results:
DECLARE
v_start TIMESTAMP;
v_end TIMESTAMP;
v_clob CLOB;
v_tmp_clob CLOB;
v_iterations PLS_INTEGER := 100000; -- Used 1,000, 10,000, and 100,000 for testing
BEGIN
v_start := SYSTIMESTAMP;
v_clob := NULL;
FOR i IN 1 .. v_iterations LOOP
v_clob := v_clob || TO_CHAR (SYSTIMESTAMP) || ', ';
END LOOP;
v_end := SYSTIMESTAMP;
DBMS_OUTPUT.put_line ('CLOB := CLOB || VARCHAR2 method: ' || TO_CHAR (v_end - v_start));
v_start := SYSTIMESTAMP;
v_clob := NULL;
FOR i IN 1 .. v_iterations LOOP
v_clob := v_clob || TO_CLOB (TO_CHAR (SYSTIMESTAMP) || ', ');
END LOOP;
v_end := SYSTIMESTAMP;
DBMS_OUTPUT.put_line ('CLOB := CLOB || TO_CLOB(VARCHAR2) method: ' || TO_CHAR (v_end - v_start));
v_start := SYSTIMESTAMP;
v_clob := NULL;
FOR i IN 1 .. v_iterations LOOP
v_tmp_clob := TO_CHAR (SYSTIMESTAMP) || ', ';
v_clob := v_clob || v_tmp_clob;
END LOOP;
v_end := SYSTIMESTAMP;
DBMS_OUTPUT.put_line ('CLOB := CLOB || TMP_CLOB method: ' || TO_CHAR (v_end - v_start));
v_start := SYSTIMESTAMP;
v_clob := NULL;
v_clob := 'h'; -- need to initialize it;
FOR i IN 1 .. v_iterations LOOP
DBMS_LOB.append (v_clob, TO_CHAR (SYSTIMESTAMP) || ', ');
END LOOP;
v_end := SYSTIMESTAMP;
DBMS_OUTPUT.put_line ('DBMS_LOB.append method: ' || TO_CHAR (v_end - v_start));
END;
The results were as follows:
1,000 Iterations CLOB := CLOB || VARCHAR2 method: +000000000 00:00:00.578000000 CLOB := CLOB || TO_CLOB(VARCHAR2) method: +000000000 00:00:00.063000000 CLOB := CLOB || TMP_CLOB method: +000000000 00:00:00.047000000 DBMS_LOB.append method: +000000000 00:00:00.172000000
10,000 Iterations CLOB := CLOB || VARCHAR2 method: +000000000 00:00:10.656000000 CLOB := CLOB || TO_CLOB(VARCHAR2) method: +000000000 00:00:00.688000000 CLOB := CLOB || TMP_CLOB method: +000000000 00:00:00.672000000 DBMS_LOB.append method: +000000000 00:00:00.687000000
100,000 Iterations CLOB := CLOB || VARCHAR2 method: +000000000 00:42:17.453000000 CLOB := CLOB || TO_CLOB(VARCHAR2) method: +000000000 00:00:17.953000000 CLOB := CLOB || TMP_CLOB method: +000000000 00:00:08.140000000 DBMS_LOB.append method: +000000000 00:00:11.110000000