gpt4 book ai didi

sql - 如何在 Oracle SQL 中选择直到特定字符的子字符串?

转载 作者:行者123 更新时间:2023-12-03 05:15:04 26 4
gpt4 key购买 nike

假设我有一个表格列,其结果如下:

ABC_blahblahblah
DEFGH_moreblahblahblah
IJKLMNOP_moremoremoremore

我希望能够编写一个查询,从所述表中选择此列,但仅返回到下划线 (_) 字符的子字符串。例如:

ABC
DEFGH
IJKLMNOP

SUBSTRING 函数似乎无法胜任这项任务,因为它是基于位置的,并且下划线的位置各不相同。

我考虑了 TRIM 函数(特别是 RTRIM 函数):

SELECT RTRIM('listofchars' FROM somecolumn) 
FROM sometable

但我不确定如何让它工作,因为它似乎只删除特定的字符列表/集,而且我实际上只是在导致下划线字符的字符之后。

最佳答案

使用 SUBSTR、INSTR 和 NVL(对于没有下划线的字符串)的组合将返回您想要的内容:

SELECT NVL(SUBSTR('ABC_blah', 0, INSTR('ABC_blah', '_')-1), 'ABC_blah') AS output
FROM DUAL

结果:

output
------
ABC

使用:

SELECT NVL(SUBSTR(t.column, 0, INSTR(t.column, '_')-1), t.column) AS output
FROM YOUR_TABLE t

引用:

附录

如果使用 Oracle10g+,您可以通过 REGEXP_SUBSTR 使用正则表达式.

关于sql - 如何在 Oracle SQL 中选择直到特定字符的子字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4389571/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com