1

我正在尝试从 blob 导出数据以在报告中使用,但是REGEXP_SUBSTR在尝试从中读取时遇到问题。将其转换为 avarchar会有所帮助,但是我发现要获得所需的数据点非常困难!

这是我如何将它传递给 varchar:

select utl_raw.cast_to_varchar2(dbms_lob.substr(NOTE)) FROM prod17import;

这是 varchar 的输出示例:

"Import: T5, ModId: #24, Time: 1/11/2017 7:32:30 AM
Records read: 1723
Added:  1723, Changed: 0
Rejected: 0, Skipped: 0
0.01 Minutes. 234422 recs/min
Map=IMCOWITHHOLDINGLAYOUTTEST9A.MPWM 
Source=W:\(filename).TXT, created: 1/10/2017 11:15:44 PM

Reject name: REJECT
Resource name: !6Imports.Liability.Maps.Life Import Resource
"

我试图只收集值 234422(可以在 1-1,000,000 之间变化)

如何在“分钟”一词之间获得该值。和“记录/分钟”?

4

1 回答 1

0

如果字符串格式一致,则使用

select regexp_substr(utl_raw.cast_to_varchar2(dbms_lob.substr(NOTE)) 
                     ,'minutes. ([0-9]+) recs/min',1,1,'i',1)
from prod17import

i作为参数指定不区分大小写的匹配。如果null您需要匹配区分大小写,请使用。

于 2017-08-27T14:18:28.717 回答