使用Oracle SQL查找字符串中的前四个数字

时间:2017-06-26 13:28:11

标签: sql oracle numbers

我必须使用Oracle SQL在表中找到第一个四个数字的序列。

input_file_name 列中,我们可以找到以下值:

RVSP_040517.M
SERIES_040517_CP.TXT
SAUDE_O10N0505.M
SERIES_040517.txt
RVSP_080517.M
SERIES_080517_CP.TXT

正如我们所看到的,之前有一组数字,但左边的第一组四个数字是我想要的。我想用这个日期(4)数字创建一个新列。

我该怎么做?

我期望从这张表中得到的结果是:

0405
0405
0505
0405
0805
0805

我试图使用 inStr ,但它没有工作

1 个答案:

答案 0 :(得分:2)

select ..., regexp_substr(input_file_name, '\d{4}') as day_month, ...
from   ...

演示(使用更多字符串来显示当没有任何四个连续数字的子串,或者多次出现这样的子串时会发生什么):

with
     test_data ( input_file_name ) as (
       select 'RVSP_040517.M'        from dual union all
       select 'SERIES_040517_CP.TXT' from dual union all
       select 'SAUDE_O10N0505.M'     from dual union all
       select 'SERIES_040517.txt'    from dual union all
       select 'RVSP_080517.M'        from dual union all
       select 'SERIES_080517_CP.TXT' from dual union all
       select 'mathguy wins'         from dual union all
       select 'GOOD_031.pdf'         from dual union all
       select 'FOUR_DIGITS_123_4'    from dual union all
       select 'A22409_11230.cpp'     from dual
     )
-- End of simulated data (for testing purposes only, not part of the solution).
-- SQL query begins BELOW THIS LINE.
select input_file_name, regexp_substr(input_file_name, '\d{4}') as day_month
from   test_data
;

INPUT_FILE_NAME       DAY_MONTH          
--------------------  ------------
RVSP_040517.M         0405                
SERIES_040517_CP.TXT  0405                
SAUDE_O10N0505.M      0505                
SERIES_040517.txt     0405                
RVSP_080517.M         0805                
SERIES_080517_CP.TXT  0805                
mathguy wins                             
GOOD_031.pdf                             
FOUR_DIGITS_123_4
A22409_11230.cpp      2240