Oracle 10g 正则表达式用法

来源:互联网 发布:sky知乎 编辑:程序博客网 时间:2024/05/17 21:54
 
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_SUBSTR返回初始参数被匹配子串替换之后的结果
select regexp_replace('page1 of 10','page(/d+)','/1') from dual,返回1 of 10,可以使用/序号获取捕获的内容。
 
原创粉丝点击