国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

Oracle存儲過程中去掉重復字符串的函數(shù)

2024-08-29 13:34:26
字體:
供稿:網(wǎng)友
    以下函數(shù)是本人在編寫Oracle數(shù)據(jù)庫存儲過程時寫的函數(shù),覺得該函數(shù)通用性較強,因此發(fā)表出來供需要的人參考.

這個函數(shù)的功能主要是用于去除給定字符串中重復的字符串.在使用中需要指定字符串的分隔符.示例:
str := MyReplace('13,14,13,444', ',');
輸出:
13,14,444

create or replace function MyReplace(oldStr varchar2, sign varchar2) return varchar2 is
  str varchar2(1000);
  currentIndex number;
  startIndex number;
  endIndex number;

  type str_type is table of varchar2(30)
       index by binary_integer;
  arr str_type;

  Result varchar2(1000);
begin    
  if oldStr is null then
    return ('');
  end if;
 
  str := oldStr;
 
  currentIndex := 0;
  startIndex := 0;
  loop
    currentIndex := currentIndex + 1;
    endIndex := instr(str, sign, 1, currentIndex);
    if (endIndex <= 0) then
      exit;
  end if;
   
  arr(currentIndex) := trim(substr(str, startIndex + 1, endIndex - startIndex - 1));
  startIndex := endIndex;
  end loop;
 
  --取最后一個字符串
  arr(currentIndex) := substr(str, startIndex + 1, length(str));
 
  --去掉重復出現(xiàn)的字符串
  for i in 1.. currentIndex - 1 loop
  for j in i + 1..currentIndex loop
    if arr(i) = arr(j) then
      arr(j) := '';
    end if;
  end loop;
  end loop;

  str := '';
  for i in 1..currentIndex loop
  if arr(i) is not null then
    str := str sign arr(i);
   
    --數(shù)組置空
    arr(i) := '';
  end if;
  end loop;
 
  --去掉前面的標識符
  Result := substr(str, 2, length(str));
  return(Result);
end MyReplace;

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 平陆县| 潮安县| 达尔| 启东市| 梓潼县| 临泉县| 原平市| 前郭尔| 民县| 长沙县| 新平| 津市市| 电白县| 四会市| 望江县| 上栗县| 同德县| 翁源县| 孟津县| 泰来县| 宣威市| 河曲县| 尚志市| 泸溪县| 福泉市| 兴隆县| 阳泉市| 厦门市| 沂南县| 长葛市| 长子县| 黄陵县| 大丰市| 鄂托克前旗| 陆良县| 松桃| 固阳县| 海林市| 循化| 长治县| 吴旗县|