oracle中截取一个字符串中的数字
发布网友
发布时间:2022-04-08 21:42
我来回答
共3个回答
热心网友
时间:2022-04-08 23:11
取子串:SUBSTR(字符串,开始位置,长度)
类型转换(字符串 -> 数值):TO_NUMBER(字符串)
如str := "I am 20 years.";
newStr := SUBSTR(str, 5, 2);\
age = TO_NUMBER(newStr);
其中newStr的数据类型为VARCHAR2,age的数据类型为NUMBER。
热心网友
时间:2022-04-09 00:29
select translate('东方路200号' , '0123456789' || '东方路200号' , '0123456789') from al;
'东方路200号' 可以是任意字符串
热心网友
时间:2022-04-09 02:04
如果Oracle版本不是太低的话,使用 正则表达式函数 REGEXP_SUBSTR 处理。
5个参数
第一个是输入的字符串
第二个是正则表达式
第三个是标识从第几个字符开始正则表达式匹配。(默认为1)
第四个是标识第几个匹配组。(默认为1)
第五个是是取值范围:
i:大小写不敏感;
c:大小写敏感;
n:点号 . 不匹配换行符号;
m:多行模式;
x:扩展模式,忽略正则表达式中的空白字符。
SQL> SELECT
2 REGEXP_SUBSTR(a,'[0-9]+')
3 FROM
4 test_reg_substr
5 WHERE
6 REGEXP_LIKE(a, '[0-9]+');
参考资料:http://hi.baidu.com/wangqing999/blog/item/625958917f5b5158d1135eff.html