最近做項目,有這樣一需求:ORACLE數據庫中求除數字、字母之外的非中文字符的正則表達式
如有如下字段,需將其中除字母、數字、漢字外的其他所有字符替換為空
'asdfsad ,,;)()!@123234#$%^&*(我w 是e ? 中國人。.//[]::‘'“”一人'
最終得到值:asdfsad123234我是中國人一人
select FN_REG_REPLACEOTHER('asdfsad ,,;)()!@#$%^&*(我是?中國人。.//[]::‘'“”一人','需要的正則表達式,'') from dual;
謝謝。以下答案就勿跟貼:
(/s)|(/,)|(/,)|(/.)|(/。)|(/:)|(/:)|(/;)|(/;)|(/))|(/))|(/()|(/))|(/()|(/‘)|(/')|(/'')|(/")|(/“)|(/”)|(/[)|(/]|(/!)|(/!)|(/@)|(/#)|(/%)|(/%)|(/^)|(/&)|(/*)|(/¥)|(/$)|(//)|(//)|(/?)|(/?))
------解決方案--------------------
select regexp_replace('asdfsad ,,;)()!@123234#$%^&*(我w 是e ? 中國人。.//[]::‘'“”一人'
,'[[:punct:]|[:blank:]|[:space:]|[:cntrl:]]','')
from dual
;
REGEXP_REPLACE('ASDFSAD,,;)
-----------------------------
asdfsad123234我w是e中國人一人
好了,本文的內容就到此為止了,希望對大家有用。
新聞熱點
疑難解答