首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从SQL Oracle中的字符串中提取第二个单词

从SQL Oracle中的字符串中提取第二个单词
EN

Stack Overflow用户
提问于 2016-12-09 00:19:24
回答 1查看 8.7K关注 0票数 2

我需要在一个专栏中得到每个名字的第二个单词,我做了关于substr和instr的研究,但是我认为我有一个逻辑错误,我就是不能指出它。

代码语言:javascript
运行
复制
select substr(vendor_name,instr(vendor_name, ' ')+1) from vendors ORDER BY vendor_id asc;

这是我当前的输出,代码可以工作,但它不能完成我希望它做的事情。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-09 00:23:51

请尝试以下查询:

代码语言:javascript
运行
复制
SELECT SUBSTR(vendor_name,
              INSTR(vendor_name, ' ', 1, 1) + 1,
              INSTR(vendor_name, ' ', 1, 2) - INSTR(vendor_name, ' ', 1, 1) - 1)
FROM vendors
ORDER BY vendor_id

要了解这是如何工作的,请以本例中的vendor_name of Boeing Corporation Inc.为例:

代码语言:javascript
运行
复制
INSTR(vendor_name, ' ', 1, 1) = 7  = first occurrence of space
INSTR(vendor_name, ' ', 1, 2) = 19 = second occurrence of space

下面是我们对子字符串的调用:

代码语言:javascript
运行
复制
SELECT SUBSTR('Boeing Corporation Inc.',
              7 + 1,
              19 - 7 - 1)

这和

代码语言:javascript
运行
复制
SELECT SUBSTR('Boeing Corporation Inc.', 8, 11) = 'Corporation'

请注意,我的答案假设vendor_name中存在第二个空格(以及第一个空格)。如果您希望在本专栏中使用复杂的数据,则可能需要使用正则表达式。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41051137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档