Oracle 10g 正则表达式用法

Oracle10G支持正在表达式函数,可以使用java的正在表达式写法;
1.         REGEXP_LIKE:
REGEXP_LIKE 与LIKE 操作符相似。如果第一个参数匹配正则表达式它就解析为TRUE。例如WHERE REGEXP_LIKE(ENAME,'^J[AO]','i') 将在ENAME 以JA 或JO 开始的情况下返回一行数据。'I' 参数指定正则表达式是大小写敏感的。另外还可以在CHECK 约束和函数索引中指定REGEXP_LIKE。例如:
ALTER TABLE EMP ADD CONSTRAINT REGEX01
CHECK (REGEXP_LIKE(ENAME,'^[[:alpha:]]+$'));
这条语句使得ENAME 字段只能包含字母和数字字符(也就是说没有空格或者标点符号)。试图插入或者更新这些数据将导致一个ORA-2290 异常,或者检查约束的有效性。
2.         REGEXP_INSTR:
REGEXP_INSTR  与 INSTR  函数类似。它返回一个字符串中匹配一个正则表达式的第一个子串的开始位置。
3.         REGEXP_SUBSTR
REGEXP_SUBSTR 返回匹配一个正则表达式的子串
4.         REGEXP_REPLACE
REGEXP_REPLAC返回初始参数被匹配子串替换之后的结果
select  regexp_replace( 'page1 of 10' , 'page(/d+)' , '/1' ) from dual ,返回1 of 10,可以使用/序号获取捕获的内容。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值