作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我有一个表格列,其结果如下:
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/
我是一名优秀的程序员,十分优秀!