5

我正在尝试从 SQL 查询(oracle 11)中的文本框中返回第一行文本。文本框的内容如下所示:

   X WITHDRAWN

   Explanation.

我想返回第一行,即 X WITHDRAWN。我不确定我是否可以指定只查看第一行,或者只在回车之前返回所有文本 - 两者都可以。

我想我需要使用 regexp_substr 但我不太确定语法。我努力了:

   regexp_substr(TABLE.TEXT,'^.*$')

但它没有用,所以任何帮助将不胜感激!

编辑:使用的解决方案:

   select regexp_substr(TABLE.TEXT, '[^,]+['||CHR(10)||']') from tab

编辑:我注意到我的答案中混合了换行符和回车符,因此我使用以下解决方案仅返回文本而不返回其他字符。

    select 
     replace(replace(regexp_substr(TABLE.TEXT, '[^,]+['||CHR(10)||']'),CHR(10),''),CHR(13),'') 
     from tab 

编辑:在@Ben 的回答之后,我将我的解决方案修改为以下内容:

select
initcap(replace(regexp_substr(TABLE.TEXT, '.*$', 1, 1, 'm'),CHR(13),''))
from tab
4

2 回答 2

9

Parado 的正则表达式多次匹配非逗号的所有内容,后跟回车符。这意味着它不适用于换行或文本中有逗号。

m Oracle 支持使用match 参数的多行表达式。使用此模式时,$匹配每行的结尾以及字符串的结尾。您可以使用它来简单地将表达式大量用于:

regexp_substr(str, '.*$', 1, 1, 'm')

即匹配匹配任何内容的字符串的第一次出现(第一行),然后是字符串的结尾,从第一个字符开始计数。

举个例子:

with strings as ( 
 select 'hi
         hi again' as str
   from dual
  union all
 select 'bye
         and again'
   from dual
        )
 select regexp_substr(str, '.*$', 1, 1, 'm')
   from strings
于 2013-07-15T12:53:40.460 回答
2

您可以尝试使用直接子字符串(回车 - Chr(10) - 是要查找的符号)而不是正则表达式:

  SubStr(Table.Text, 1, decode(InStr(Table.Text, Chr(10)), 0, Length(Table.Text), InStr(Table.Text, Chr(10))) - 1)
于 2013-07-15T11:19:37.427 回答