Das liegt daran, dass -- ist ein Teil von --> Trennzeichen, aber kein Teil von -> Trennzeichen.
Auch wenn Ihr Datenwert --> hat Diese Abfrage sollte nicht fehlschlagen. Wie unten.
SQL> select Sys_Connect_By_Path('SomeText B-->More Text' || ':' || 'SomeText A-->More Text', ' --> ') "myNewVar"
from dual
connect by rownum<=3;
myNewVar
----------------------------------------------------
--> SomeText B-->More Text:SomeText A-->More Text
--> SomeText B-->More Text:SomeText A-->More Text --> SomeText B-->More Text:SomeText A-->More Text
--> SomeText B-->More Text:SomeText A-->More Text --> SomeText B-->More Text:SomeText A-->More Text --> SomeText B-->More Text:SomeText A-->More Text
Das obige Trennzeichen ist --> , beachten Sie die Leerzeichen. Dieser Leerraum wird als Teil des Trennzeichens betrachtet, d. h. chr(1)||chr(45)||chr(45)||chr(62)||chr(1) . Diese gesamte Zeichenfolge ist nicht Teil Ihrer Daten oder Ihres Spaltenwerts.
Wobei wie unten ein Fehler auftreten würde
SQL> select Sys_Connect_By_Path('SomeText B-->More Text' || ':' || 'SomeText A-->More Text', '-->') "myNewVar"
from dual
connect by rownum<=3;
ORA-30004: when using SYS_CONNECT_BY_PATH function, cannot have seperator as part of column value
30004. 00000 - "when using SYS_CONNECT_BY_PATH function, cannot have seperator as part of column value"
*Cause:
*Action: Use another seperator which does not occur in any column value,
then retry.
Das obige Trennzeichen ist --> , beachten Sie, dass es keine Leerzeichen gibt, dh chr(45)||chr(45)||chr(62) . Diese gesamte Zeichenfolge ist tatsächlich ein Teil Ihrer Daten oder Ihres Spaltenwerts und daher der Fehler.
Und hier ist eine Lösung (Leistung nicht getestet)
select regexp_replace(Sys_Connect_By_Path('SomeText B-->More Text' || ':' || 'SomeText A-->More Text', ' -> '),' -> ','-->') "myNewVar"
from dual
connect by rownum<=3;
myNewVar
--------------------------------------
-->SomeText B-->More Text:SomeText A-->More Text
-->SomeText B-->More Text:SomeText A-->More Text-->SomeText B-->More Text:SomeText A-->More Text
-->SomeText B-->More Text:SomeText A-->More Text-->SomeText B-->More Text:SomeText A-->More Text-->SomeText B-->More Text:SomeText A-->More Text
Erklärung - Hier (in der Abfrage oben) -> (mit Leerzeichen) ist hier nicht Teil der Daten, d. h. --> . Sobald die Spalte durch den Pfad verbunden ist, wird regexp_replace ersetzt alle Vorkommen von -> mit --> Auf diese Weise erhalten Sie also immer noch --> als Trennzeichen anstelle von -> .