Clob對象轉換爲String

  /**
     * @title: clobParseString
     * @description:TODO Clob對象轉換爲String
     * @author: yubo  
     * @param clob
     * @return
     * @throws SQLException
     * @date:2016-1-6下午4:01:42
     */
    public static String clobParseString(Clob clob) throws SQLException{
        String result = "";
        if(clob != null){
            result = clob.getSubString((long)1,(int)clob.length());
        }
        return result;
    }

 行轉列oracle:oracle

create or replace type type_concatstr_clob as object
(
  total  clob,
  static function ODCIAggregateInitialize(sctx IN OUT type_concatstr_clob) return number,
  member function ODCIAggregateIterate(self IN OUT type_concatstr_clob,value IN clob) return number,
  member function ODCIAggregateTerminate(self IN type_concatstr_clob,returnValue OUT clob,flags IN number) return number,
  member function ODCIAggregateMerge(self IN OUT type_concatstr_clob,ctx2 IN type_concatstr_clob) return number
)
/

create or replace type body type_concatstr_clob
is
  --在concatstr的基礎上改寫
  static function ODCIAggregateInitialize(sctx IN OUT type_concatstr_clob) return number
  is
  begin
    sctx := type_concatstr_clob(null);
    return ODCIConst.Success;
  end;

  member function ODCIAggregateIterate(self IN OUT type_concatstr_clob,value IN clob) return number
  is
  begin
    self.total := self.total || ',' || value;
    return ODCIConst.Success;
  end;

  member function ODCIAggregateTerminate(self IN type_concatstr_clob,returnValue OUT clob,flags IN number) return number
  is
  begin
    returnValue := ltrim(self.total,',');
    return ODCIConst.Success;
  end;

  member function ODCIAggregateMerge(self IN OUT type_concatstr_clob,ctx2 IN type_concatstr_clob) return number
  is
  begin
    self.total := self.total || ctx2.total;
    return ODCIConst.Success;
  end;
end;
/
create or replace function f_concatstr_clob(input varchar2) return clob
  parallel_enable
  aggregate using type_concatstr_clob;

For example:spa

SELECT u.c_agencyname FROM (
SELECT f_concatstr_clob(e.c_agencyno||':'||e.c_agencyname) c_agencyname FROM   tagencyinfo e) u ;
相關文章
相關標籤/搜索