除了 regexp_like(name ,'[张]三');还有什么写法? 对应哪个版本的?
解决方案 »
- Oracle聚合函数优缺点是什么?如何优化。
- powerdesigner的逆向工程问题
- 关于emp示例表计算工资的小问题,急。
- 快照问题
- oralce索引能disable吗
- 求 当天中午12点 距 格林乔治时间1970年1月1日0点 的秒数
- oracle数据库升级到10.2.0.3.0,本机可以连接数据库,其他机器无法连接数据库
- 请高手指点迷津--transparent gateway for sybase 等待......
- 服务器端为oracle815,客户端为9i的可以进行数据的读写吗?
- 如何在clob中存取大型中文对象?
- oracle并发处理SOS
- ERwin autoincrement的问题,初学ERWIN,大家帮一下
它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符。特殊字符:
'^' 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。
'$' 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 'n' 或 'r'。
'.' 匹配除换行符 n之外的任何单字符。
'?' 匹配前面的子表达式零次或一次。
'*' 匹配前面的子表达式零次或多次。
'+' 匹配前面的子表达式一次或多次。
'( )' 标记一个子表达式的开始和结束位置。
'[]' 标记一个中括号表达式。
'{m,n}' 一个精确地出现次数范围,m=<出现次数<=n,'{m}'表示出现m次,'{m,}'表示至少出现m次。
'|' 指明两项之间的一个选择。例子'^([a-z]+|[0-9]+)$'表示所有小写字母或数字组合成的字符串。
num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。
正则表达式的一个很有用的特点是可以保存子表达式以后使用, 被称为Backreferencing. 允许复杂的替换能力
如调整一个模式到新的位置或者指示被代替的字符或者单词的位置. 被匹配的子表达式存储在临时缓冲区中,
缓冲区从左到右编号, 通过数字符号访问。 下面的例子列出了把名字 aa bb cc 变成
cc, bb, aa.
Select REGEXP_REPLACE('aa bb cc','(.*) (.*) (.*)', '3, 2, 1') FROM dual;
REGEXP_REPLACE('ELLENHILDISMIT
cc, bb, aa
'' 转义符。字符簇:
[[:alpha:]] 任何字母。
[[:digit:]] 任何数字。
[[:alnum:]] 任何字母和数字。
[[:space:]] 任何白字符。
[[:upper:]] 任何大写字母。
[[:lower:]] 任何小写字母。
[[:punct:]] 任何标点符号。
[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。各种操作符的运算优先级
转义符
(), (?:), (?=), [] 圆括号和方括号
*, +, ?, {n}, {n,}, {n,m} 限定符
^, $, anymetacharacter 位置和顺序
| “或”操作本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/jsjzzh/archive/2007/03/29/1545190.aspx
还有更高级的。正则是个很强大的匹配模式,oracle 10g以上支持。
参考下这个http://www.regexlab.com/zh/regref.htm