Oracle正则表达式函数:regexp_like、regexp_substr、regexp_instr、regexp_replace

  /*
  ORACLE中的支持正则表达式的函数主要有下面四个:
  1,REGEXP_LIKE :与LIKE的功能相似
  2,REGEXP_INSTR :与INSTR的功能相似
  3,REGEXP_SUBSTR :与SUBSTR的功能相似
  4,REGEXP_REPLACE :与REPLACE的功能相似
  它们在用法上与Oracle SQL 函数LIKE、INSTR、SUBSTR 和REPLACE 用法相同,
  但是它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符。
  POSIX 正则表达式由标准的元字符(metacharacters)所构成:
  '^' 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。
  '$' 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹
  配 '\n' 或 '\r'。
  '.' 匹配除换行符之外的任何单字符。
  '?' 匹配前面的子表达式零次或一次。
  '+' 匹配前面的子表达式一次或多次。
  '*' 匹配前面的子表达式零次或多次。
  '|' 指明两项之间的一个选择。例子'^([a-z]+|[0-9]+)$'表示所有小写字母或数字组合成的
  字符串。
  '( )' 标记一个子表达式的开始和结束位置。
  '[]' 标记一个中括号表达式。
  '{m,n}' 一个精确地出现次数范围,m= WHERE regexp_like(name,'(王|圣|王圣峰)')
  查询 包含 A,E,F 的 字段
  SQL> Select 性质 From 部门 Where Regexp_Like(性质, '.*[A].*[E].*[F].*');
  性质
  -------------------------------------------------- ----------
  A,B,C,D,E,F
  A,E,F,G
  A,B,C,D,E,F,G,H,I,J,L,M,N
  A,B,C,D,E,F,G,H,I,J,L,M,N
  A,E,F
  A,B,C,D,E,F,G
  A,E,F
  A,B,C,D,E,F,G,H,I,J,L,M,N
  A,E,F,G
  A,E,F
  A,E,F
  A,D,E,F
  12 rows selected
  解释:
  该 SQL 语句显示了用圆括号括住的三个单独的子表达式。每一个单独的子表达式包含一个匹配元字符 (.),并紧跟着 * 元字符,表示任何字符(除换行符之外)都必须匹配零次或更多次。空格将各个子表达式分开,空格也必须匹配。圆括号创建获取值的子表达式,并且可以用 \digit 来引用。第一个子表达式被赋值为 \1 ,第二个 \2,以此类推。这些后向引用被用在这个函数的最后一个参数 (\3, \1 \2) 中,这个函数有效地返回了替换子字符串,并按期望的格式来排列它们(包括逗号和空格)。表 11 详细说明了该正则表达式的各个组成部分。
  http://www.nipei.com/article/9865
  来源:地址:
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值