自定义oracle函数获取字符串中特殊字符

create or replace function getVar(varlist in varchar2, varName in varchar2)
  return varchar2 as
  result_v      varchar2(50);
  temp_pos      number(10);
  tempStr_v     varchar2(4000);
  temp_length_v number(10);
begin
  -----查找参数在varlist字符串中的位置,并计算出值的下标索引
  temp_pos := instr(chr(01) || varlist, chr(01) || varName || '=') +
              length(varName) + 1;
  if temp_pos <= length(varName) + 1 then
    return ''; ---位置为0时表示没有该参数。返回空
  else
    ---获得等号后面的所有值
    tempStr_v := substr(varlist, temp_pos);
    ---获得等号后面第一个分割符号的位置
    temp_pos := instr(tempStr_v, chr(01));
    if temp_pos = 0 then
      return tempStr_v;
    else
      return substr(tempStr_v, 1, temp_pos - 1);
    end if;
  end if;
end;

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle ,可以使用自定义聚合函数来实现类似于 `wm_concat` 的功能,该函数可以将多行字符串按照指定的分隔符拼接成一个 CLOB 类型的字符串,并返回该字符串。 以下是一个示例代码: ```sql CREATE OR REPLACE TYPE t_string_agg AS OBJECT ( g_string CLOB, STATIC FUNCTION ODCIAggregateInitialize(sctx IN OUT t_string_agg) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateIterate(self IN OUT t_string_agg, value IN VARCHAR2) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateTerminate(self IN t_string_agg, returnValue OUT CLOB, flags IN NUMBER) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateMerge(self IN OUT t_string_agg, ctx2 IN t_string_agg) RETURN NUMBER ); CREATE OR REPLACE TYPE BODY t_string_agg IS STATIC FUNCTION ODCIAggregateInitialize(sctx IN OUT t_string_agg) RETURN NUMBER IS BEGIN sctx := t_string_agg(CLOB('')); RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateIterate(self IN OUT t_string_agg, value IN VARCHAR2) RETURN NUMBER IS BEGIN IF self.g_string IS NULL THEN self.g_string := value; ELSE self.g_string := self.g_string || ', ' || value; END IF; RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateTerminate(self IN t_string_agg, returnValue OUT CLOB, flags IN NUMBER) RETURN NUMBER IS BEGIN returnValue := self.g_string; RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateMerge(self IN OUT t_string_agg, ctx2 IN t_string_agg) RETURN NUMBER IS BEGIN IF self.g_string IS NULL THEN self.g_string := ctx2.g_string; ELSE self.g_string := self.g_string || ', ' || ctx2.g_string; END IF; RETURN ODCIConst.Success; END; END; CREATE OR REPLACE FUNCTION string_agg(input VARCHAR2) RETURN CLOB AGGREGATE USING t_string_agg; ``` 在上述代码,我们定义了一个 `t_string_agg` 类型,它包含一个 CLOB 类型的字符串和四个成员函数,分别是 `ODCIAggregateInitialize`、`ODCIAggregateIterate`、`ODCIAggregateTerminate` 和 `ODCIAggregateMerge`。这四个函数的作用分别是初始化聚合函数状态、将输入值聚合到状态、从状态获取聚合结果并返回、合并两个状态。 然后,我们使用 `AGGREGATE USING` 子句来定义一个名为 `string_agg` 的聚合函数,该函数使用刚刚定义的 `t_string_agg` 类型实现。最后,我们可以像使用内置聚合函数一样使用 `string_agg` 函数来实现字符串拼接功能: ```sql SELECT string_agg(last_name) FROM employees; ``` 以上示例代码,我们将 `employees` 表的所有 `last_name` 字段的值拼接成一个 CLOB 类型的字符串

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值