Solved

String parsing in PL/SQL: how to produce a list using "double-asterisk" separated fields in a VARCHAR2.

Posted on 2008-10-06
5
970 Views
Last Modified: 2013-12-18
Please assume you have the following string, stored in a VARCHAR2(4000):

ASTRING = '**NE**NECOLL1**NECOLL2**NE37509999**';

Using double-asterisk (==> **) as separator, I would like to write a VIEW script:

CREATE OR REPLACE VIEW STRING_SPLITTER AS SELECT ...........

The VIEW STRING_SPLITTER has to produce the following output, if SELECTed:

SELECT * FROM STRING_SPLITTER;

NE
NECOLL1
NECOLL2
NE37509999
4 row(s) selected

Any clues?!
0
Comment
Question by:CRISTIANO_CORRADI
  • 3
  • 2
5 Comments
 
LVL 15

Accepted Solution

by:
Shaju Kumbalath earned 500 total points
ID: 22648800
0
 

Author Comment

by:CRISTIANO_CORRADI
ID: 22648894
Perfect!
0
 

Author Comment

by:CRISTIANO_CORRADI
ID: 22648902
I've customized, for my application, the following solution found in the suggested hypertextual link:


Using a Pipelined Function

An alternative to a standard PL/SQL function (from 9i onwards) is the use of pipelined functions. 

SQL> CREATE TYPE test_type AS TABLE OF VARCHAR2(100);

  2  /
 

Type created.
 

SQL> CREATE OR REPLACE FUNCTION f_convert2(p_list IN VARCHAR2)

  2    RETURN test_type

  3  PIPELINED

  4  AS

  5    l_string       LONG := p_list || ',';

  6    l_comma_index  PLS_INTEGER;

  7    l_index        PLS_INTEGER := 1;

  8  BEGIN

  9    LOOP

 10      l_comma_index := INSTR(l_string, ',', l_index);

 11      EXIT WHEN l_comma_index = 0;

 12      PIPE ROW ( SUBSTR(l_string, l_index, l_comma_index - l_index) );

 13      l_index := l_comma_index + 1;

 14    END LOOP;

 15    RETURN;

 16  END f_convert2;

 17  /
 

Function created.
 

SQL> SELECT * FROM TABLE(f_convert('AAA,BBB,CCC,D'));
 

COLUMN_VALUE

--------------------------------------------------------------------------------

AAA

BBB

CCC

D
 

4 rows selected.

The advantage of pipelined functions is that the PIPE ROW statement means that the whole collection is not populated all at once, as in Table Functions. In that respect, it is much more memory efficient. 

Open in new window

0
 

Author Closing Comment

by:CRISTIANO_CORRADI
ID: 31503358
Thank you very much for your kind cooperation.
0
 
LVL 15

Expert Comment

by:Shaju Kumbalath
ID: 22648916

select answer
from (
select trim(substr(str, instr(str, '**', 1, level) + 2,
instr(str, '**', 1, level + 1) - instr(str, '**', 1, level) - 2)) answer
, level lv
, lag(level, 1, 0) over (order by level) lg
from (
select '**NE**NECOLL1**NECOLL2**NE37509999**' str
from dual)
connect by instr(str, '**', 1, level) > 0)
where answer is not null
and lv != lg;  
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Join & Write a Comment

Working with Network Access Control Lists in Oracle 11g (part 1) Part 2: http://www.e-e.com/A_9074.html So, you upgraded to a shiny new 11g database and all of a sudden every program that used UTL_MAIL, UTL_SMTP, UTL_TCP, UTL_HTTP or any oth…
How to Create User-Defined Aggregates in Oracle Before we begin creating these things, what are user-defined aggregates?  They are a feature introduced in Oracle 9i that allows a developer to create his or her own functions like "SUM", "AVG", and…
This video shows how to copy a database user from one database to another user DBMS_METADATA.  It also shows how to copy a user's permissions and discusses password hash differences between Oracle 10g and 11g.
This video shows how to Export data from an Oracle database using the Original Export Utility.  The corresponding Import utility, which works the same way is referenced, but not demonstrated.

758 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now