溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Oracle字符串截取和拼接應(yīng)用

發(fā)布時(shí)間:2020-06-15 02:29:00 來源:網(wǎng)絡(luò) 閱讀:1530 作者:孤月2012 欄目:關(guān)系型數(shù)據(jù)庫

今天有人問了個(gè)關(guān)于Oracle字符串截取和拼接的問題,讓我?guī)退麑懗鯯QL,看了下問題描述還比較清晰就試著解決下,利用午休時(shí)間把功能實(shí)現(xiàn)了,問題看似不難,但思路一定要清晰,不然就亂了,關(guān)鍵大量應(yīng)用了Oracle的substr 和instr函數(shù),下面貼出問題和腳本:

問題:sql中一個(gè)字段值為:1788987565327、768374872394903、21437238740213483874629、23412341234252345。其中頓號(hào)間隔的每一組數(shù)字位數(shù)和尾數(shù)不定,現(xiàn)在要使前面這個(gè)字段值中頓號(hào)前的數(shù)字尾數(shù)即7、3、9、5都分別加1,變成8、4、0、6輸出成1788987565328、768374872394904、21437238740213483874620、23412341234252346。注意其中第三個(gè)數(shù),從9加1后,輸出成0,而不是10

腳本:

declare
    targetstr varchar2(2000);
    strlength number;
    position number;
    maxposition number;
    retrunstr varchar2(2000);
    tempstr varchar2(2000);
    endstr number;
begin
    targetstr := '1788987565327、768374872394903、21437238740213483874629、23412341234252345';
    maxposition := 0;
    select LENGTH(targetstr) into strlength  from dual;
    for i in 1..strlength loop
        select instr(str,'、',1,i) into position from (select targetstr as str from dual);
        --dbms_output.PUT_LINE(position);
        if position > 0 then 
            if maxposition = 0 then 
                select substr(str,0,instr(str,'、',1,1)-1) into retrunstr from (select targetstr as str from dual);
                select TO_NUMBER(substr(restr,-1)) into endstr from (select retrunstr as restr from dual);
                if endstr = 3 or endstr = 5 or endstr = 7 then
                    endstr := endstr + 1;
                elsif endstr = 9 then
                    endstr := 0;
                end if;
                select substr(str,0,instr(str,'、',1,1)-2)||TO_CHAR(endstr) into retrunstr from (select targetstr as str from dual);
            elsif maxposition < position then
                select substr(str,instr(str,'、',1,i-1)+1,instr(str,'、',1,i)-instr(str,'、',1,i-1)-1) into tempstr from (select targetstr as str from dual);
                select TO_NUMBER(substr(restr,-1)) into endstr from (select tempstr as restr from dual);
                if endstr = 3 or endstr = 5 or endstr = 7 then
                    endstr := endstr + 1;
                elsif endstr = 9 then
                    endstr := 0;
                end if;
                select substr(str,1,length(str)-1) ||TO_CHAR(endstr) into tempstr from (select tempstr as str from dual);
                retrunstr := retrunstr || '、'|| tempstr;             
            end if;
            maxposition := position;
        else
            if maxposition > position then
                --特別處理最后一段
                tempstr := '';
                select substr(str,maxposition-length(str)) into tempstr from (select targetstr as str from dual);
                select TO_NUMBER(substr(restr,-1)) into endstr from (select tempstr as restr from dual);
                if endstr = 3 or endstr = 5 or endstr = 7 then
                    endstr := endstr + 1;
                elsif endstr = 9 then
                    endstr := 0;
                end if;
                select substr(str,1,length(str)-1) ||TO_CHAR(endstr) into tempstr from (select tempstr as str from dual);
                retrunstr := retrunstr || '、'|| tempstr;
            end if;
            exit;
        end if;
    end loop;
    dbms_output.PUT_LINE(retrunstr);
end;

運(yùn)行結(jié)果如下:

原字符串:1788987565327、768374872394903、21437238740213483874629、23412341234252345

14:03:38  **** SCRIPT STARTED: 02-Apr-2015 14:03:38 ****
14:03:38  declare
14:03:38      targetstr varchar2(2000);
14:03:38  ...
14:03:39  PL/SQL block executed
1788987565328、768374872394904、21437238740213483874620、23412341234252346
14:03:39  **** SCRIPT ENDED 02-Apr-2015 14:03:39 ****
14:03:39  End Script Execution

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI