0

我在 Oracle sql 中运行以下命令。我能够获得我想要的结果,但想了解如何应用替代方案。我想提取总是从第 18 个字符开始的名称,但之后的名称和字符总是不同的。

示例:“分配给组 5678 中的用户 John Smith”

这可以在表 history.description 中找到。

如果我使用 SUBSTR (HISTORY.DESCRIPTION, 18, INSTR (HISTORY.DESCRIPTION,' in')-18 AS NAME

我得到了我想要的“John Smith”结果

我正在尝试 SUBSTR (HISTORY.DESCRIPTION,18, REGEXP_SUBSTR (HISTORY.DESCRIPTION, '(\S*)(\w)', 'in')

Ora 01722 无效号码错误是我得到的。

我不明白如何应用此功能

4

1 回答 1

1

你能假设获取第一个“ user”和最后一个“”之间的所有文本是安全的in吗?该文本会保持不变吗?

SQL> with history(description) as (
      select 'Assigned to user John Smith in group 5678' from dual
    )
    select regexp_substr(description, 'user\s(.*)\sin', 1, 1, 'i', 1) name
    from history;

NAME
----------
John Smith

SQL>

或者要真正收紧正则表达式以匹配更多字符串,您可以将其更改为从第 18 个字符开始并匹配所有字符,但不包括“in group”文本开头的空格:

'^.{17}(.+) in group \d+$'
于 2016-03-04T16:27:59.120 回答