首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle instr职位

Oracle instr职位
EN

Stack Overflow用户
提问于 2016-09-12 22:20:01
回答 2查看 139关注 0票数 0

我有15个字符的字符串,需要循环拉动字母'a‘出现的位置。我打算使用游标在字符串中循环,但不确定如何保存每个位置的出现。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-09-12 22:31:53

像这样将字符串拆分成每个字符,然后根据所需的值进行过滤?

代码语言:javascript
复制
-- data setup to create a single value to test
WITH dat as (select 'ABCDEACDFA' val from DUAL)
--
SELECT lvl, strchr 
from (
    -- query to break the string into individual characters, returning a row for each
    SELECT level lvl, substr(dat.val,level,1) strchr
    FROM dat 
    CONNECT BY level <= length(val)
) WHERE strchr = 'A';

returns:
LVL    STRCHR
1      A
6      A
10     A
票数 1
EN

Stack Overflow用户

发布于 2016-09-12 23:28:23

下面是一个不同的方法,使用了一个较少的select和一个正则表达式。不过,我不相信它会对你的性能问题有所帮助。请试一试,让我们知道:

代码语言:javascript
复制
SQL> with tbl(str) as (
     select 'Aabjggaklkjha' from dual
   )
   select level as position
   from tbl
   where upper(REGEXP_SUBSTR(str, '.', 1, level)) = 'A'
   connect by level <= length(str);

  POSITION
----------
         1
         2
         7
        13

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

https://stackoverflow.com/questions/39452533

复制
相关文章

相似问题

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