Discussions
Categories
- 197.1K All Categories
- 2.5K Data
- 546 Big Data Appliance
- 1.9K Data Science
- 450.7K Databases
- 221.9K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 552 MySQL Community Space
- 479 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.1K ORDS, SODA & JSON in the Database
- 555 SQLcl
- 4K SQL Developer Data Modeler
- 187.2K SQL & PL/SQL
- 21.3K SQL Developer
- 296.3K Development
- 17 Developer Projects
- 139 Programming Languages
- 293K Development Tools
- 110 DevOps
- 3.1K QA/Testing
- 646.1K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 158 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.2K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 19 Java Essentials
- 162 Java 8 Questions
- 86K Java Programming
- 81 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 205 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 466 LiveLabs
- 39 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 175 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 233 Portuguese
Sorting contents of a text column

Hi,
I have a output is below format. in DLL_OUTPUT column. I need to sort this output for ALTER statments and place it back in the table.
DDL_OUTPUT
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("STATUS" CONSTRAINT "NN_ADP
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("STATUS_DATE" CONSTRAINT "N
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("BATCHN" CONSTRAINT "NN_ADP
ATER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("DISBURSEN" CONSTRAINT "NN_
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" ADD CONSTRAINT "PK_ADP_ALPHA_DISB_X HPUX
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("PAY_METHOD" CONSTRAINT "NN
ALTER TABLE "UNIACC"."ADP_ALPHA_DISB_XREF" MODIFY ("ADP_DISBURSEN" CONSTRAINT
I am using below code to do that but it is missing the last line.
OPEN constraint_list;
LOOP
a_data := ddl_arr();
a_sort := ddl_arr();
v_sorted_ddl := NULL;
FETCH constraint_list INTO v_oracle_sid, v_obj_name, v_obj_type, v_ddl_output;
v_list := v_ddl_output;
LOOP
l_idx := instr(v_list,chr(10));
IF l_idx > 0 THEN
v_ddl_output:=substr(v_list,1,l_idx-1);
v_list := substr(v_list,l_idx+length(chr(10)));
IF (INSTR(v_ddl_output,'ALTER') > 0) THEN
a_data.extend;
a_data(a_data.count) := v_ddl_output;
END IF;
ELSE
exit;
END IF;
END LOOP;
select cast(multiset(select * from table(a_data) order by 1) as ddl_arr)
into a_sort from dual;
FOR l_loop in 1..a_sort.count
LOOP
v_sorted_ddl := v_sorted_ddl || a_sort(l_loop) || chr(13);
END LOOP;
UPDATE table tddl
SET tddl.ddl_output = v_sorted_ddl
WHERE tddl.oracle_sid = v_oracle_sid
AND tddl.obj_name = v_obj_name
AND tddl.obj_type = v_obj_type
AND tddl.daemon_type = v_dc_daemon_type;
EXIT WHEN constraint_list%NOTFOUND;
END LOOP;
CLOSE constraint_list;
How would I achieve that. Please note this works fine in 10g but create problem in 11G and last line from the output is missed while updating the table.