大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
oracle使用正则表达式列入两个固定字符中间的数据方法:
在海门等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、成都网站建设、外贸营销网站建设 网站设计制作定制制作,公司网站建设,企业网站建设,品牌网站制作,网络营销推广,成都外贸网站建设,海门网站建设费用合理。
1、正则表达式的使用需要用到关键字REGEXP,用定义一组字符,表示匹配125三个字符。
2、digit表示匹配任意数字,DOT表示ALL表示所有,连起来匹配包括换行符默认模式下.是不能匹配行符n的。
select regexp_replace('XX路1001弄12幢102室', '\d+幢', '') from dual
帮你测试过了
Oracle g数据库内建了符合IEEE POSIX (Portable Operating System for Unix)标准的正则表达式 熟练使用正则表达式 可以写出简洁 强大的SQL语句
正则表达式有几个优点优于常见的LIKE操作符和INSTR SUBSTR及REPLACE 函数的 这些传统的SQL 函数不便于进行模式匹配 只有LIKE 操作符通过使用%和_字符匹配 但LIKE不支持表达式的重复 复杂的更替 字符范围 字符列表和POSIX 字符类等等
元字符(Meta Character)
Sql代码
^ 使表达式定位至一行的开头
$ 使表达式定位至一行的末尾
* 匹配 次或更多次
? 匹配 次或 次
+ 匹配 次或更多次
{m} 正好匹配 m 次
{m } 至少匹配 m 次
{m n} 至少匹配 m 次但不超过 n 次
[:alpha:] 字母字符
[:lower:] 小写字母字符
[:upper:] 大写字母字符
[:digit:] 数字
[:alnum:] 字母数字字符
[:space:] 空白字符(禁止打印) 如回车符 换行符 竖直制表符和换页符[:punct:] 标点字符
[:cntrl:] 控制字符(禁止打印)
[:print:] 可打印字符 | 分隔替换选项 通常与分组操作符 () 一起使用
( ) 将子表达式分组为一个替换单元 量词单元或后向引用单元
[char] 字符列表
Oracle g提供了四个regexp function: REGEXP_LIKE REGEXP_REPLACE REGEXP_INSTR REGEXP_SUBSTR
Sql代码
REGEXP_LIKE 比较一个字符串是否与正则表达式匹配
(srcstr pattern [ match_option])
REGEXP_INSTR 在字符串中查找正则表达式 并且返回匹配的位置
(srcstr pattern [ position [ occurrence [ return_option [ match_option]]]])
REGEXP_SUBSTR 返回与正则表达式匹配的子字符串
(srcstr pattern [ position [ occurrence [ match_option]]])
REGEXP_REPLACE 搜索并且替换匹配的正则表达式
(srcstr pattern [ replacestr [ position [ occurrence [ match_option]]]]) 其中各参数的含义为:
Sql代码
srcstr: 被查找的字符数据
pattern: 正则表达式
occurrence: 出现的次数 默认为
position: 开始位置
return_option: 默认值为 返回该模式的起始位置 值为 则返回符合匹配条件的下一个字符的起始位置
replacestr: 用来替换匹配模式的字符串
match_option: 匹配方式选项 缺省为c
c case sensitive
I case insensitive
n ( )匹配任何字符(包括newline)
m 字符串存在换行的时候被作为多行处理
下面通过一些具体的例子来说明如何使用这四个函数 首先创建一个测试数据表
Sql代码
SQL create table person (
first_name varchar( )
last_name varchar( )
email varchar( )
zip varchar( ));
Table created
SQL insert into person values ( Steven Chen );
row created
SQL insert into person values ( James Li || chr( ) || b d f );
row created
SQL mit;
Commit plete
SQL select * from person;
FIRST_NAME LAST_NAME EMAIL ZIP
Steven Chen
James Li b d f
REGEXP_LIKE
Sql代码
SQL select zip as invalid_zip from person where regexp_like(zip [^[:digit:]] );
INVALID_ZIP
b d f
SQL select first_name from person where regexp_like(first_name ^S *n$ );
FIRST_NAME
Steven
SQL select first_name from person where regexp_like(first_name ^s *n$ );
no rows selected
SQL select first_name from person where regexp_like(first_name ^s *n$ c );
no rows selected
SQL select first_name from person where regexp_like(first_name ^s *n$ i );
FIRST_NAME
Steven
SQL select email from person where regexp_like(email ^james *$ );
no rows selected
SQL select email from person where regexp_like(email ^james *$ n );
SQL select email from person where regexp_like(email ^li *$ );
no rows selected
SQL select email from person where regexp_like(email ^li *$ m );
REGEXP_INSTR
Sql代码
查找zip中第一个非数字字符的位置
SQL select regexp_instr(zip [^[:digit:]] ) as position from person;
POSITION
从第三个字符开始 查找zip中第二个非数字字符的位置
SQL select regexp_instr(zip [^[:digit:]] ) as position from person;
POSITION
从第三个字符开始 查找zip中第二个非数字字符的下一个字符位置
SQL select regexp_instr(zip [^[:digit:]] ) as position from person;
POSITION
REGEXP_SUBSTR
Sql代码
SQL select regexp_substr(zip [^[:digit:]] ) as zip from person;
ZIP
b
SQL select regexp_substr(zip [^[:digit:]] ) as zip from person;
ZIP
f
REGEXP_REPLACE
Sql代码
把zip中所有非数字字符替换为
SQL update person set zip=regexp_replace(zip [^[:digit:]] )
where regexp_like(zip [^[:digit:]] );
row updated
SQL select zip from person;
ZIP
后向引用(backreference)
后向引用是 一个很有用的特性 它能够把子表达式的匹配部分保存在临时缓冲区中 供以后重用 缓冲区从左至右进行编号 并利用 \digit 符号进行访问 子表达式用一组圆括号来显示 利用后向引用可以实现较复杂的替换功能
Sql代码
SQL select regexp_replace( Steven Chen ( *) ( *) \ \ ) 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:]]+$ ));
lishixinzhi/Article/program/Oracle/201311/18745
select regexp_replace('If IsValid("date", to_date(Trim(LK_01.TX_DATE) Then "19111111" then ','if\s+isvalid.*\((.*?)\).*?then','\1 ',1,0,'i') from dual;
这样的话就是得出LK_01.TX_DATE这个结果啦
嘻嘻
regexp_like 2。regexp_substr 3。regexp_instr 4。regexp_replace 看函数名称大概就能猜到有什么用了。 regexp_like 只能用于条件表达式,和 like 类似,但是使用的正则表达式进行匹配,语法很简单: regexp_substr 函数,和 substr 类似,用于拾取合符正则表达式描述的字符子串,语法如下: regexp_instr 函数,和 instr 类似,用于标定符合正则表达式的字符子串的开始位置,语法如下: regexp_replace 函数,和 replace 类似,用于替换符合正则表达式的字符串,语法如下: 这里解析一下几个参数的含义: 1。source_char,输入的字符串,可以是列名或者字符串常量、变量。 2。pattern,正则表达式。 3。match_parameter,匹配选项。 取值范围: i:大小写不敏感; c:大小写敏感;n:点号 . 不匹配换行符号;m:多行模式;x:扩展模式,忽略正则表达式中的空白字符。 4。position,标识从第几个字符开始正则表达式匹配。 5。occurrence,标识第几个匹配组。 6。replace_string,替换的字符串。 说了一堆文绉绉的,现在开始实例演练了,在此之前先建好一个表。 01 create table tmp as 02 with data as ( 03 select 'like' as id ,'a9999' as str from dual union all 04 select 'like' ,'a9c' from dual union all 05 select 'like' ,'A7007' from dual union all 06 select 'like' ,'123a34cc' from dual union all
a[[:space:]]{3}b
看a b后面似乎还有空格,但是没看出来具体几个。
[[:space:]]
-- 注释
-- 如上表示任意空白,你可以在b后面再添加