I have a database table like this:
id | check_number | amount
1 | 1001]1002]1003 | 200]300]100
2 | 2001]2002 | 500]1000
3 | 3002]3004]3005]3007 | 100]300]600]200
I want to separate the records into something like this:
id | check_number | amount
1 | 1001 | 200
2 | 1002 | 300
3 | 1003 | 100
. | . | .
. | . | .
. | . | .
How do I do this just using SQL in Oracle and SQL Server?
Thanks,
Milo
In Oracle Only, using the CONNECT BY LEVEL method (see here), with several caveats:
Essentially we blow out the query using the hierarchical functions of oracle and then only get the substrings for the data in each “column” of data inside the check_number and amount columns.
Major Caveat: The data to be transformed must have the same number of “data elements” in both columns, since we use the first column to “count” the number of items to be transformed.
I have tested this on 11gR2. YMMV depending on DMBS version as well. Note the need to use the “PRIOR” operator, which prevents oracle from going into an infinite connect by loop.