giuste risposte sono già state date, ma solo elaborando un po '.
Simulando la vostra situazione attuale:
SQL> declare
2 cursor cur_t
3 is
4 select ename
5 from emp
6 where deptno = 10
7 ;
8 v_texttoadd emp.ename%type;
9 v_string varchar2(100);
10 begin
11 open cur_t;
12 loop
13 fetch cur_t into v_texttoadd;
14 v_string := v_string || v_texttoadd;
15 exit when cur_t%notfound;
16 end loop
17 ;
18 dbms_output.put_line(v_string);
19 end;
20/
CLARKKINGMILLERMILLER
PL/SQL-procedure is geslaagd.
Qui MILLER viene stampato due volte. Con solo il passaggio della dichiarazione EXIT e l'assegnazione v_string, si ottiene il risultato desiderato:
SQL> declare
2 cursor cur_t
3 is
4 select ename
5 from emp
6 where deptno = 10
7 ;
8 v_texttoadd emp.ename%type;
9 v_string varchar2(100);
10 begin
11 open cur_t;
12 loop
13 fetch cur_t into v_texttoadd;
14 exit when cur_t%notfound;
15 v_string := v_string || v_texttoadd;
16 end loop
17 ;
18 dbms_output.put_line(v_string);
19 end;
20/
CLARKKINGMILLER
PL/SQL-procedure is geslaagd.
Tuttavia, il codice PL/SQL diventa più facile quando si utilizza un cursore-for-loop. È quindi possibile ignorare la variabile v_texttoadd e il numero di linee in loop diminuisce:
SQL> declare
2 cursor cur_t
3 is
4 select ename
5 from emp
6 where deptno = 10
7 ;
8 v_string varchar2(100);
9 begin
10 for r in cur_t
11 loop
12 v_string := v_string || r.ename;
13 end loop
14 ;
15 dbms_output.put_line(v_string);
16 end;
17/
CLARKKINGMILLER
PL/SQL-procedure is geslaagd.
È inoltre possibile utilizzare SQL dritto per svolgere il lavoro. Un esempio con la clausola modello di SQL, se si è in versione 10g o superiore:
SQL> select string
2 from (select string
3 , rn
4 from emp
5 where deptno = 10
6 model
7 dimension by (rownum rn)
8 measures (ename, cast(null as varchar2(100)) string)
9 (string[any] order by rn desc = ename[cv()] || string[cv()+1]
10 )
11 )
12 where rn = 1
13/
STRING
-----------------------------------------------------------------------------------
CLARKKINGMILLER
1 rij is geselecteerd.
Saluti, Rob.
fonte
2009-05-22 06:59:18
Non ha funzionato per il mio. Dai un'occhiata alla mia risposta se ti interessa. –