Oracle SQL:使用regexp_substr返回第一行字符串

Oracle SQL:使用regexp_substr返回第一行字符串,第1张

概述我试图从SQL查询(oracle 11)中的文本框返回第一行文本.文本框的内容如下所示: X WITHDRAWN Explanation. 我想返回顶行,即X WITHDRAWN.我不确定我是否可以指定只查看第一行,或者只是在回车之前返回所有文本 – 要么可以工作. 我想我需要使用regexp_substr,但我对语法不太确定.我试过了: regexp_substr(TABLE.TEXT, 我试图从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的回答,我已将我的解决方案修改为以下内容:

selectinitcap(replace(regexp_substr(table.TEXT,'.*$',1,'m'),''))from tab
解决方法 Parado的正则表达式匹配多次不是逗号的所有内容,后跟回车符.这意味着它不适用于换行或文本中有逗号.

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

regexp_substr(str,'m')

这匹配匹配任何内容的字符串的第一个匹配项(第一行),后跟字符串的结尾,从第一个字符开始计算.

举个例子:

with strings as (  select 'hi         hi again' as str   from dual  union all select 'bye         and again'   from dual        ) select regexp_substr(str,'m')   from strings
总结

以上是内存溢出为你收集整理的Oracle SQL:使用regexp_substr返回第一行字符串全部内容,希望文章能够帮你解决Oracle SQL:使用regexp_substr返回第一行字符串所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1166489.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存