我试图从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
答案 0 :(得分:7)
Parado的正则表达式匹配多次不是逗号的所有内容,后跟回车符。这意味着它不适用于换行或文本中有逗号。
Oracle使用m
match parameter支持多行表达式。使用此模式时,$
匹配每行的结尾以及字符串的结尾。您可以使用它简单地将表达式大量地用于:
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
答案 1 :(得分:1)
您可以尝试使用直接子字符串(使用回车符 - Chr(10) - 要查找的符号)而不是正则表达式:
SubStr(Table.Text, 1, decode(InStr(Table.Text, Chr(10)), 0, Length(Table.Text), InStr(Table.Text, Chr(10))) - 1)