大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
oracle的正则表达式(10g才可以用)
创新互联服务项目包括平潭网站建设、平潭网站制作、平潭网页制作以及平潭网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,平潭网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到平潭省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
oracle的正则表达式(regular expression)简单介绍
目前,正则表达式已经在很多软件中得到广泛的应用,包括*nix(Linux, Unix等),HP等操作系统,PHP,C#,Java等开发环境。
Oracle 10g正则表达式提高了SQL灵活性。有效的解决了数据有效性,重复词的辨认, 无关的空白检测,或者分解多个正则组成的字符串等问题。
Oracle 10g支持正则表达式的四个新函数分别是:REGEXP_LIKE、REGEXP_INSTR、REGEXP_SUBSTR、和REGEXP_REPLACE。
它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符。
特殊字符:
'^' 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。
'$' 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 '\n' 或'\r'。
'.' 匹配除换行符 \n之外的任何单字符。
'?' 匹配前面的子表达式零次或一次。
'*' 匹配前面的子表达式零次或多次。
'+' 匹配前面的子表达式一次或多次。
'( )' 标记一个子表达式的开始和结束位置。
'[]' 标记一个中括号表达式。
'{m,n}' 一个精确地出现次数范围,m=出现次数=n,'{m}'表示出现m次,'{m,}'表示至少出现m次。
'|' 指明两项之间的一个选择。例子'^([a-z]+|[0-9]+)$'表示所有小写字母或数字组合成的字符串。
\num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。
正则表达式的一个很有用的特点是可以保存子表达式以后使用,被称为Backreferencing. 允许复杂的替换能力
如调整一个模式到新的位置或者指示被代替的字符或者单词的位置. 被匹配的子表达式存储在临时缓冲区
中,缓冲区从左到右编号, 通过\数字符号访问。 下面的例子列出了把名字 aa bb cc 变成cc, bb, aa.
Select REGEXP_REPLACE('aa bb cc','(.*) (.*) (.*)', '\3, \2, \1') FROM dual;
REGEXP_REPLACE('ELLENHILDISMIT
cc, bb, aa
'\' 转义符。
字符簇:
[[:alpha:]] 任何字母。
[[:digit:]] 任何数字。
[[:alnum:]] 任何字母和数字。
[[:space:]] 任何白字符。
[[:upper:]] 任何大写字母。
[[:lower:]] 任何小写字母。
[[unct:]] 任何标点符号。
[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。
各种操作符的运算优先级
\ 转义符
(), (?, (?=), [] 圆括号和方括号
*, +, ?, {n}, {n,}, {n,m} 限定符
^, $, \anymetacharacter 位置和顺序
| “或”操作
--测试数据
create table test(mc varchar2(60));
insert into test values('112233445566778899');
insert into test values('22113344 5566778899');
insert into test values('33112244 5566778899');
insert into test values('44112233 5566 778899');
insert into test values('5511 2233 4466778899');
insert into test values('661122334455778899');
insert into test values('771122334455668899');
insert into test values('881122334455667799');
insert into test values('991122334455667788');
insert into test values('aabbccddee');
insert into test values('bbaaaccddee');
insert into test values('ccabbddee');
insert into test values('ddaabbccee');
insert into test values('eeaabbccdd');
insert into test values('ab123');
insert into test values('123xy');
insert into test values('007ab');
insert into test values('abcxy');
insert into test values('The final test is is is how to find duplicate words.');
commit;
一、REGEXP_LIKE
select * from test where regexp_like(mc,'^a{1,3}');
select * from test where regexp_like(mc,'a{1,3}');
select * from test where regexp_like(mc,'^a.*e$');
select * from test where regexp_like(mc,'^[[:lower:]]|[[:digit:]]');
select * from test where regexp_like(mc,'^[[:lower:]]');
Select mc FROM test Where REGEXP_LIKE(mc,'[^[:digit:]]');
Select mc FROM test Where REGEXP_LIKE(mc,'^[^[:digit:]]');
二、REGEXP_INSTR
Select REGEXP_INSTR(mc,'[[:digit:]]$') from test;
Select REGEXP_INSTR(mc,'[[:digit:]]+$') from test;
Select REGEXP_INSTR('The price is $400.','\$[[:digit:]]+') FROM DUAL;
Select REGEXP_INSTR('onetwothree','[^[[:lower:]]]') FROM DUAL;
Select REGEXP_INSTR(',,,,,','[^,]*') FROM DUAL;
Select REGEXP_INSTR(',,,,,','[^,]') FROM DUAL;
三、REGEXP_SUBSTR
SELECT REGEXP_SUBSTR(mc,'[a-z]+') FROM test;
SELECT REGEXP_SUBSTR(mc,'[0-9]+') FROM test;
SELECT REGEXP_SUBSTR('aababcde','^a.*b') FROM DUAL;
四、REGEXP_REPLACE
Select REGEXP_REPLACE('Joe Smith','( ){2,}', ',') AS RX_REPLACE FROM dual;
Select REGEXP_REPLACE('aa bb cc','(.*) (.*) (.*)', '\3, \2, \1') FROM dual;
a[[:space:]]{3}b
看a b后面似乎还有空格,但是没看出来具体几个。
[[:space:]]
-- 注释
-- 如上表示任意空白,你可以在b后面再添加
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
Oracle Database g 的一个新特性大大提高了您搜索和处理字符数据的能力 这个特性就是正规表达式 是一种用来描述文本模式的表示方法 很久以来它已在许多编程语言和大量 UNIX 实用工具中出现过了 Oracle 的正规表达式的实施是以各种 SQL 函数和一个 WHERE 子句操作符的形式出现的 如果您不熟悉正规表达式 那么这篇文章可以让您了解一下这种新的极其强大然而表面上有点神秘的功能 已经对正规表达式很熟悉的读者可以了解如何在 Oracle SQL 语言的环境中应用这种功能 什么是正规表达式? 正规表达式由一个或多个字符型文字和/或元字符组成 在最简单的格式下 正规表达式仅由字符文字组成 如正规表达式 cat 它被读作字母 c 接着是字母 a 和 t 这种模式匹配 cat location 和 catalog 之类的字符串 元字符提供算法来确定 Oracle 如何处理组成一个正规表达式的字符 当您了解了各种元字符的含义时 您将体会到正规表达式用于查找和替换特定的文本数据是非常强大的 验证数据 识别重复关键字的出现 检测不必要的空格 或分析字符串只是正规表达式的许多应用中的一部分 您可以用它们来验证电话号码 邮政编码 电子邮件地址 社会安全号码 IP 地址 文件名和路径名等的格式 此外 您可以查找如 HTML 标记 数字 日期之类的模式 或任意文本数据中符合任意模式的任何事物 并用其它的模式来替换它们 用 Oracle Database g 使用正规表达式 您可以使用最新引进的 Oracle SQL REGEXP_LIKE 操作符和 REGEXP_INSTR REGEXP_SUBSTR 以及 REGEXP_REPLACE 函数来发挥正规表达式的作用 您将体会到这个新的功能如何对 LIKE 操作符和 INSTR SUBSTR 和 REPLACE 函数进行了补充 实际上 它们类似于已有的操作符 但现在增加了强大的模式匹配功能 被搜索的数据可以是简单的字符串或是存储在数据库字符列中的大量文本 正规表达式让您能够以一种您以前从未想过的方式来搜索 替换和验证数据 并提供高度的灵活性 正规表达式的基本例子 在使用这个新功能之前 您需要了解一些元字符的含义 句号 ( ) 匹配一个正规表达式中的任意字符(除了换行符) 例如 正规表达式 a b 匹配的字符串中首先包含字母 a 接着是其它任意单个字符(除了换行符) 再接着是字母 b 字符串 axb xaybx 和 abba 都与之匹配 因为在字符串中隐藏了这种模式 如果您想要精确地匹配以 a 开头和以 b 结尾的一条三个字母的字符串 则您必须对正规表达式进行定位 脱字符号 (^) 元字符指示一行的开始 而美元符号 ($) 指示一行的结尾(参见表 ) 因此 正规表达式 ^a b$ 匹配字符串 aab abb 或 axb 将这种方式与 LIKE sup ;Ù×÷·û提供的类似的模式匹配 a_b 相比较 其中 (_) 是单字符通配符 默认情况下 一个正规表达式中的一个单独的字符或字符列表只匹配一次 为了指示在一个正规表达式中多次出现的一个字符 您可以使用一个量词 它也被称为重复操作符 如果您想要得到从字母 a 开始并以字母 b 结束的匹配模式 则您的正规表达式看起来像这样 ^a *b$ * 元字符重复前面的元字符 ( ) 指示的匹配零次 一次或更多次 LIKE 操作符的等价的模式是 a%b 其中用百分号 (%) 来指示任意字符出现零次 一次或多次 表 给出了重复操作符的完整列表 注意它包含了特殊的重复选项 它们实现了比现有的 LIKE 通配符更大的灵活性 如果您用圆括号括住一个表达式 这将有效地创建一个可以重复一定次数的子表达式 例如 正规表达式 b(an)*a 匹配 ba bana banana yourbananasplit 等 Oracle 的正规表达式实施支持 POSIX (可移植操作系统接口)字符类 参见表 中列出的内容 这意味着您要查找的字符类型可以非常特别 假设您要编写一条仅查找非字母字符的 LIKE 条件 — 作为结果的 WHERE 子句可能不经意就会变得非常复杂 POSIX 字符类必须包含在一个由方括号 ([]) 指示的字符列表中 例如 正规表达式 [[:lower:]] 匹配一个小写字母字符 而 [[:lower:]]{ } 匹配五个连续的小写字母字符 除 POSIX 字符类之外 您可以将单独的字符放在一个字符列表中 例如 正规表达式 ^ab[cd]ef$ 匹配字符串 abcef 和 abdef 必须选择 c 或 d 除脱字符 (^) 和连字符 ( ) 之外 字符列表中的大多数元字符被认为是文字 正规表达式看起来很复杂 这是因为一些元字符具有随上下文环境而定的多重含义 ^ 就是这样一种元字符 如果您用它作为一个字符列表的第一个字符 它代表一个字符列表的非 因此 [^[:digit:]] 查找包含了任意非数字字符的模式 而 ^[[:digit:]] 查找以数字开始的匹配模式 连字符 ( ) 指示一个范围 正规表达式 [a m] 匹配字母 a 到字母 m 之间的任意字母 但如果它是一个字符行中的第一个字符(如在 [ afg] 中) 则它就代表连字符 之前的一个例子介绍了使用圆括号来创建一个子表达式 它们允许您通过输入更替元字符来输入可更替的选项 这些元字符由竖线 (|) 分开 例如 正规表达式 t(a|e|i)n 允许字母 t 和 n 之间的三种可能的字符更替 匹配模式包括如 tan ten tin 和 Pakistan 之类的字 但不包括 teen mountain 或 tune 作为另一种选择 正规表达式 t(a|e|i)n 也可以表示为一个字符列表 t[aei]n 表 汇总了这些元字符 虽然存在更多的元字符 但这个简明的概述足够用来理解这篇文章使用的正规表达式 REGEXP_LIKE 操作符 REGEXP_LIKE 操作符向您介绍在 Oracle 数据库中使用时的正规表达式功能 表 列出了 REGEXP_LIKE 的语法 下面的 SQL 查询的 WHERE 子句显示了 REGEXP_LIKE 操作符 它在 ZIP 列中搜索满足正规表达式 [^[:digit:]] 的模式 它将检索 ZIPCODE 表中的那些 ZIP 列值包含了任意非数字字符的行 SELECT zipFROM zipcodeWHERE REGEXP_LIKE(zip [^[:digit:]] )ZIP ab xy ababcxy 这个正规表达式的例子仅由元字符组成 更具体来讲是被冒号和方括号分隔的 POSIX 字符类 digit 第二组方括号(如 [^[:digit:]] 中所示)包括了一个字符类列表 如前文所述 需要这样做是因为您只可以将 POSIX 字符类用于构建一个字符列表 REGEXP_INSTR 函数 这个函数返回一个模式的起始位置 因此它的功能非常类似于 INSTR 函数 新的 REGEXP_INSTR 函数的语法在表 中给出 这两个函数之间的主要区别是 REGEXP_INSTR 让您指定一种模式 而不是一个特定的搜索字符串 因而它提供了更多的功能 接下来的示例使用 REGEXP_INSTR 来返回字符串 Joe Smith Berry Lane San Joseph CA 中的五位邮政编码模式的起始位置 如果正规表达式被写为 [[:digit:]]{ } 则您将得到门牌号的起始位置而不是邮政编码的 因为 是第一次出现五个连续数字 因此 您必须将表达式定位到该行的末尾 正如 $ 元字符所示 该函数将显示邮政编码的起始位置 而不管门牌号的数字个数 SELECT REGEXP_INSTR( Joe Smith Berry Lane San Joseph CA [[:digit:]]{ }$ )AS rx_instrFROM dualRX_INSTR 编写更复杂的模式 让我们在前一个例子的邮政编码模式上展开 以便包含一个可选的四位数字模式 您的模式现在可能看起来像这样 [[:digit:]]{ }( [[:digit:]]{ })?$ 如果您的源字符串以 位邮政编码或 位 + 位邮政编码的格式结束 则您将能够显示该模式的起始位置 SELECT REGEXP_INSTR( Joe Smith Berry Lane San Joseph CA [[:digit:]]{ }( [[:digit:]]{ })?$ )AS starts_atFROM dualSTARTS_AT 在这个示例中 括弧里的子表达式 ( [[:digit:]]{ }) 将按 ? 重复操作符的指示重复零次或一次 此外 企图用传统的 SQL 函数来实现相同的结果甚至对 SQL 专家也是一个挑战 为了更好地说明这个正规表达式示例的不同组成部分 表 包含了一个对单个文字和元字符的描述 REGEXP_SUBSTR 函数 ·Çsup ;£ÀàËÆÓÚ SUBSTR 函数的 REGEXP_SUBSTR 函数用来提取一个字符串的一部分 表 显示了这个新函数的语法 在下面的示例中 匹配模式 [^ ]* 的字符串将被返回 该正规表达式搜索其后紧跟着空格的一个逗号 然后按 [^ ]* 的指示搜索零个或更多个不是逗号的字符 最后查找另一个逗号 这种模式看起来有点像一个用逗号分隔的值字符串 SELECT REGEXP_SUBSTR( first field second field third field [^ ]* )FROM dualREGEXP_SUBSTR( FIR second field REGEXP_REPLACE 函数 让我们首先看一下传统的 REPLACE SQL 函数 它把一个字符串用另一个字符串来替换 假设您的数据在正文中有不必要的空格 您希望用单个空格来替换它们 利用 REPLACE 函数 您需要准确地列出您要替换多少个空格 然而 多余空格的数目在正文的各处可能不是相同的 下面的示例在 Joe 和 Smith 之间有三个空格 REPLACE 函数的参数指定要用一个空格来替换两个空格 在这种情况下 结果在原来的字符串的 Joe 和 Smith 之间留下了一个额外的空格 SELEC lishixinzhi/Article/program/Oracle/201311/18225
用 Oracle Database 10g 使用正规表达式
您可以使用最新引进的 Oracle SQL REGEXP_LIKE 操作符和 REGEXP_INSTR、REGEXP_SUBSTR 以及 REGEXP_REPLACE 函数来发挥正规表达式的作用。您将体会到这个新的功能如何对 LIKE 操作符和 INSTR、SUBSTR 和 REPLACE 函数进行了补充。实际上,它们类似于已有的操作符,但现在增加了强大的模式匹配功能。被搜索的数据可以是简单的字符串或是存储在数据库字符列中的大量文本。正规表达式让您能够以一种您以前从未想过的方式来搜索、替换和验证数据,并提供高度的灵活性。
正规表达式的基本例子
在使用这个新功能之前,您需要了解一些元字符的含义。句号 (.) 匹配一个正规表达式中的任意字符(除了换行符)。例如,正规表达式 a.b 匹配的字符串中首先包含字母 a,接着是其它任意单个字符(除了换行符),再接着是字母 b。字符串 axb、xaybx 和 abba 都与之匹配,因为在字符串中隐藏了这种模式。如果您想要精确地匹配以 a 开头和以 b 结尾的一条三个字母的字符串,则您必须对正规表达式进行定位。脱字符号 (^) 元字符指示一行的开始,而美元符号 ($) 指示一行的结尾(参见表1:附表见第4页)。因此, 正规表达式 ^a.b$ 匹配字符串 aab、abb 或 axb。将这种方式与 LIKE 操作符提供的类似的模式匹配 a_b 相比较,其中 (_) 是单字符通配符。
默认情况下,一个正规表达式中的一个单独的字符或字符列表只匹配一次。为了指示在一个正规表达式中多次出现的一个字符,您可以使用一个量词,它也被称为重复操作符。.如果您想要得到从字母 a 开始并以字母 b 结束的匹配模式,则您的正规表达式看起来像这样:^a.*b$。* 元字符重复前面的元字符 (.) 指示的匹配零次、一次或更多次。LIKE 操作符的等价的模式是 a%b,其中用百分号 (%) 来指示任意字符出现零次、一次或多次。
表 2 给出了重复操作符的完整列表。注意它包含了特殊的重复选项,它们实现了比现有的 LIKE 通配符更大的灵活性。如果您用圆括号括住一个表达式,这将有效地创建一个可以重复一定次数的子表达式。例如,正规表达式 b(an)*a 匹配 ba、bana、banana、yourbananasplit 等。仅供参考!
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