当前所在位置:珠峰网资料 >> 计算机 >> Oracle认证 >> 正文
Oracle正则表达式(三)
发布时间:2010/11/8 10:24:51 来源:www.xue.net 编辑:城市总裁吧
     从第三个字符开始,查找zip中第二个非数字字符的位置

  SQL> select regexp_instr(zip, '[^[:digit:]]', 3, 2) as position from person;

  POSITION

  ----------

  0

  6

  从第三个字符开始,查找zip中第二个非数字字符的下一个字符位置

  SQL> select regexp_instr(zip, '[^[:digit:]]', 3, 2, 1) as position from person;

  POSITION

  ----------

  0

  7

  3。REGEXP_SUBSTR

  Sql代码

  SQL> select regexp_substr(zip, '[^[:digit:]]') as zip from person;

  ZIP

  ------------------

  b

  SQL> select regexp_substr(zip, '[^[:digit:]]', 3, 2) as zip from person;

  ZIP

  ------------

  f

  4。REGEXP_REPLACE

  Sql代码

  把zip中所有非数字字符替换为0

  SQL> update person set zip=regexp_replace(zip, '[^[:digit:]]', '0')

  2  where regexp_like(zip, '[^[:digit:]]');

  1 row updated.

  SQL> select zip from person;

  ZIP

  ------

  123456

  103050

  后向引用(backreference):

  后向引用是 一个很有用的特性。它能够把子表达式的匹配部分保存在临时缓冲区中,供以后重用 。缓冲区从左至右进行编号,并利用 \digit 符号进行访问。子表达式用一组圆括号来显示。利用后向引用可以实现较复杂的替换功能。

  Sql代码

  SQL> select regexp_replace('Steven Chen', '(.*) (.*)', '\2, \1') as reversed_name from dual;

  REVERSED_NAME

  --------------------

  Chen, Steven

  在DDL中也可以正则表达式,比如Constraint, index, view

  Sql代码

  SQL> alter table person add constraint constraint_zip check (regexp_like(zip, '^[[:digit:]]+$'));

  SQL> create index person_idx on person(regexp_substr(last_name, '^[[:upper:]]'));

广告合作:400-664-0084 全国热线:400-664-0084
Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号
珠峰网 版权所有 All Rights Reserved