Ако имате Oracle 10g, REGEXP_REPLACE е доста гъвкав.
Използване на следния низ като тест:
chr(9) || 'Q qwer' || chr(9) || chr(10) ||
chr(13) || 'qwerqwer qwerty' || chr(9) ||
chr(10) || chr(13)
[[:space:]]
ще премахне всички интервали и ([[:cntrl:]])|(^\t)
regexp ще премахне непечатаемите знаци и раздели.
select
tester,
regexp_replace(tester, '(^[[:space:]]+)|([[:space:]]+$)',null)
regexp_tester_1,
regexp_replace(tester, '(^[[:cntrl:]^\t]+)|([[:cntrl:]^\t]+$)',null)
regexp_tester_2
from
(
select
chr(9) || 'Q qwer' || chr(9) || chr(10) ||
chr(13) || 'qwerqwer qwerty' || chr(9) ||
chr(10) || chr(13) tester
from
dual
)
Връщане:
- REGEXP_TESTER_1 :"
Qqwerqwerqwerqwerty
" - REGEXP_TESTER_2 :"
Q qwerqwerqwer qwerty
"
Надяваме се, че това е от полза.