要找到 PRODUCT_INFORMATION 表的 PRODUCT_NAME 列中名称包含 SSP/S、SSP/V、SSS/V 或 SSS/S 的所有产品,执行以下脚本:
SELECT product_name
FROM oe.product_information
WHERE regexp_like (product_name, 'SS[PS]/[VS]');
REGEXP_INSTR 函数返回字符串中给定模式的位置。检查语法:
REGEXP_INSTR(srcstr, pattern [, position [, occurrence
[, return_option [, match_option]]]])
在该函数中:
position:是搜索的起始位置
occurrence:是要搜索的匹配项
return_option:指示匹配项的开头或结尾位置
match_option:提供了更改默认匹配的选项。它可以包含以下一个或多个值:
“c”:使用区分大小写的匹配(默认值)
“i”:使用不区分大小写的匹配
“n”:允许匹配任何字符的运算符来匹配换行符
“m”:将源字符串作为多行处理
To search the product?names to find the location of the first nonalphabetic character (regardless of whether it is uppercase or lowercase), execute the following script:
@reinstr.sql
COLUMN non_alpha FORMAT 9999999999
SELECT product_name, REGEXP_INSTR(product_name, '[^[:alpha:]]')non_alpha
FROM oe.product_information ;
请注意,[^[::]] 表示一个字符类,并匹配该类中的任何字符;[:alpha:] 匹配任何字母字符。在本示例中,您将通过使用 ^ 对该表达式取非。
REGEXP_SUBSTR 函数根据匹配项的模式返回给定字符串。检查语法:
REGEXP_SUBSTR(srcstr, pattern [, position
[, occurrence [, match_option]]])
在该函数中:
position:是搜索的起始位置
occurrence:是要搜索的匹配项
match_option:提供了更改默认匹配的选项。它可以包含以下一个或多个值:
“c”:使用区分大小写的匹配(默认值)
“i”:使用不区分大小写的匹配
“n”:允许匹配任何字符的运算符来匹配换行符
“m”:将源字符串作为多行处理
您希望从 CUSTOMERS 表中提取电子邮件名,但是只提取位于瑞士的客户的电子邮件名。为此,您需要返回 CUST_EMAIL 列(该列位于 NLS_TERRITORY 为 Switzerland 的客户的 @ 符号前面)中的内容。执行以下脚本:
@resubstr.sql
SELECT REGEXP_SUBSTR(cust_email, '[^@]+')
FROM oe.customers
WHERE nls_territory = 'SWITZERLAND' ;
请注意,在本示例中,结果返回第一个没有 @ 符号的子字符串。
REGEXP_REPLACE 函数使用替换字符串所替换的模式的每一个匹配项来返回给定字符串。检查语法:
REGEXP_REPLACE(srcstr, pattern [,replacestr [, position
[, occurrence [, match_option]]]])
在该函数中:
position:是搜索的起始位置
occurrence:是要搜索的匹配项
replacestr:是替换模式的字符串
match_option:提供了更改默认匹配的选项。它可以包含以下一个或多个值:
“c”:使用区分大小写的匹配(默认值)
“i”:使用不区分大小写的匹配
“n”:允许匹配任何字符的运算符
“m”:将源字符串作为多行处理
要返回 PRODUCT_INFORMATION 表的 CATALOG_URL 列中的信息,可以对该列执行完全扫描。但是,这将导致返回上百个行,这是因为它列出了多个目录域中的特定 HTML 页面位置。
在该示例中,您只想要查找单个域名本身,而不是它们所包含的低级页面。要查找不包含所有不必要信息的域名,使用 REGEXP_REPLACE 函数。执行以下脚本:
@rereplace.sql
SELECT UNIQUE REGEXP_REPLACE (catalog_url, 'http://([^/]+).*', '\1')
FROM oe.product_information ;
以下是有关如何处理字符串的介绍:
http://
该表达式首先查找该字符串文字;此处没有特殊的元字符。
([^/]+)
然后,该表达式搜索一系列字符(只要它们不是斜线 (/))。
该表达式在用该部分遍历该字符串的剩余部分时结束。
匹配表达式替换为后向引用 1,它是在第一组括号中匹配的任何内容。
@multiport.sql
SELECT regexp_substr(translated_name, '^[a-z]+')
FROM oe.product_descriptions
WHERE language_id = 'PT'
AND translated_name like 'G%' ;
请注意,未显示该数据。
^ 位于方括号外部,这意味着您将搜索以任何字符(从 a 到 z)开头的任何字符串或子字符串。
执行同一查询,但这次使用不区分大小写的“i”。执行以下脚本:
@multiport2.sql
SELECT regexp_substr(translated_name, '^[a-z]+', 1, 1, 'i')
FROM oe.product_descriptions
WHERE language_id = 'PT'
AND translated_name like 'G%' ;
由于在遇到非英文字符时,返回的字符串被截断,因此结果仍不完整。这是因为范围 [a-z] 对 NLS_LANGUAGE 比较敏感。范围表达式对 NLS_SORT 很敏感,在本例中,它派生自 NLS_LANGUAGE。您需要相应地设置 NLS_LANGUAGE 参数,以返回完整结果。执行以下查询:
@multiport3.sql
ALTER SESSION SET NLS_LANGUAGE=PORTUGUESE;
SELECT regexp_substr(translated_name, '^[a-z]+', 1, 1, 'i')
FROM oe.product_descriptions
WHERE language_id = 'PT'
AND translated_name like 'G%' ;
最后一步是查看用英语和葡萄牙语表示的结果以确保已经完成了翻译。执行以下脚本:
@multiport4.sql
SELECT REGEXP_SUBSTR(i.product_name, '^[a-z]+', 1, 1, 'i') || ' = '
|| regexp_substr(d.translated_name, '^[a-z]+', 1, 1, 'i')
FROM oe.product_descriptions d, oe.product_information i
WHERE d.language_id = 'PT'
AND d.translated_name like 'G%'
AND i.product_id = d.product_id ;
ALTER SESSION SET NLS_LANGUAGE=AMERICAN;
在 CUSTOMERS 表的 CUST_EMAIL 列上添加一个校验约束可以确保只接受包含 @ 符号的字符串。执行以下脚本:
@chkemail.sql
INSERT INTO customers VALUES
(9999,'Christian','Patel',
cust_address_typ ('1003 Canyon Road','87501',
'Santa Fe','NM','US'),
phone_list_typ ('+1 505 243 4144'),'us','AMERICA','100',
'ChrisP+creme.com', 149, null, null, null, null, null) ;
由于未执行验证,因此接受了未包含 @ 符号的电子邮件地址。
运行脚本之后,在开始下一步之前,在 SQL> 提示符处运行 ROLLBACK 语句。
ROLLBACK;
通过执行以下脚本实施约束:
@chkemail2.sql
ALTER TABLE customers
ADD CONSTRAINT cust_email_addr
CHECK(REGEXP_LIKE(cust_email,'@'))NOVALIDATE ;