Oracle SQL:使用regexp_substr返回第一行字符串
发布时间:2021-03-15 15:22:03 所属栏目:站长百科 来源:网络整理
导读:我试图从SQL查询(oracle 11)中的文本框返回第一行文本.文本框的内容如下所示: X WITHDRAWN Explanation. 我想返回顶行,即X WITHDRAWN.我不确定我是否可以指定只查看第一行,或者只是在回车之前返回所有文本 – 要么可以工作. 我想我需要使用regexp_substr,但
我试图从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,'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 (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |