• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

lob to csv

mysql 搞代码 4年前 (2022-01-09) 14次浏览 已收录 0个评论

将相应的 大型对象LOB类型数据转为相应的CSV格式 返回 ,采用本文来源gaodai$ma#com搞$$代**码)网8了piplined 的方式,也就是 运行出一条数据 就返回一条 ,不是全部都执行完了 再返回的形式 PL/SQL lob-to-csv piplined function clob_to_csv (p_csv_clob in clob, p_separator in varchar2 := g

将相应的 大型对象LOB类型数据转为相应的CSV格式 返回 ,采用了piplined 的方式,也就是 运行出一条数据 就返回一条 ,不是全部都执行完了 再返回的形式 PL/SQL lob-to-csv piplined <style> .CodeEntity .code_pieces ul.piece_anchor{width:25px;position:absolute;top:25px;left:-30px;z-index:1000;} .CodeEntity .code_pieces ul.piece_anchor li{width:25px;background: #efe;margin-bottom:2px;} .CodeEntity .code_pieces ul.piece_anchor li{border-left:3px #40AA63 solid;border-right:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li:hover{border-right:3px #40AA63 solid;border-left:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li a{color: #333;padding: 3px 10px;} .CodeEntity .code_pieces .jump_to_code{visibility:hidden;position:relative;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code{visibility:visible;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code a{text-decoration:none;} .CodeEntity .code_pieces h2 i{float:right;font-style:normal;font-weight:normal;} .CodeEntity .code_pieces h2 i a{font-size:9pt;background: #FFFFFF;color:#00A;padding: 2px 5px;text-decoration:none;} </style> <!—ecms -ecms

    –> <!—ecms -ecms

  • $velocityCount
  • –> <!—ecms -ecms

–>

function clob_to_csv (p_csv_clob in clob,                      p_separator in varchar2 := g_default_separator,                      p_skip_rows in number := 0) return t_csv_tab pipelinedas  l_line_separator         varchar2(2) := chr(13) || chr(10);--行的 分割符号 \r\n   l_last                   pls_integer;--上一次的扫描位置  l_current                pls_integer;--这一次的扫描位置  l_line                   varchar2(32000);  l_line_number            pls_integer := 0;  l_from_line              pls_integer := p_skip_rows + 1;  l_line_array             t_str_array;  l_row                    t_csv_line := t_csv_line (null, null,  -- line number, line raw                                                     null, null, null, null, null, null, null, null, null, null,   -- lines 1-10                                                     null, null, null, null, null, null, null, null, null, null);  -- lines 11-20begin  /*  Purpose:      convert clob to CSV  Remarks:      based on code from http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:1352202934074                              and  http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:744825627183  Who     Date        Description  ------  ----------  --------------------------------  MBR     31.03.2010  Created  fartpig 07.03.2011  noted  */  -- If the file has a DOS newline (cr+lf), use that: 如果文件时DOS的格式就是用 \r\n  -- If the file does not have a DOS newline, use a Unix newline (lf) 如果不是就采用 unix标准 \n  -- 通过检索 \r\n 是否存在   if (nvl(dbms_lob.instr(p_csv_clob, l_line_separator, 1, 1),0) = 0) then    l_line_separator := chr(10);  end if;  l_last := 1;--设定上一次扫描位置为 1   loop    --检索 当前分割符号的位置    --为了能够顺利的将文件读完 需要 将传入的 LOB结尾加上一个 分割符号    l_current := dbms_lob.instr (p_csv_clob || l_line_separator, l_line_separator, l_last, 1);    --当 没有找到时候 退出    exit when (nvl(l_current,0) = 0);    --递增  行号    l_line_number := l_line_number + 1;        if l_from_line <= l_line_number then      --通过 上一次的标记和这一次的标记 获得相应的 子值      --注意这里的参数 顺序和 instr不同 ,偏移量和长度 是反过来的      l_line := dbms_lob.substr(p_csv_clob || l_line_separator, l_current - l_last + 1, l_last);      --l_line := replace(l_line, l_line_separator, '');      --将得到的 子值的 \r\n 替换掉      l_line := replace(l_line, chr(10), '');      l_line := replace(l_line, chr(13), '');      --调用相应的 csv to array  API来处理 得到这个行 的结果数组      l_line_array := csv_to_array (l_line, p_separator);      --将获得的值 进行那个封装到 记录中 通过pip row返回      l_row.line_number := l_line_number;      l_row.line_raw := substr(l_line,1,4000);      l_row.c001 := get_array_value (l_line_array, 1);      l_row.c002 := get_array_value (l_line_array, 2);      l_row.c003 := get_array_value (l_line_array, 3);      l_row.c004 := get_array_value (l_line_array, 4);      l_row.c005 := get_array_value (l_line_array, 5);      l_row.c006 := get_array_value (l_line_array, 6);      l_row.c007 := get_array_value (l_line_array, 7);      l_row.c008 := get_array_value (l_line_array, 8);      l_row.c009 := get_array_value (l_line_array, 9);      l_row.c010 := get_array_value (l_line_array, 10);      l_row.c011 := get_array_value (l_line_array, 11);      l_row.c012 := get_array_value (l_line_array, 12);      l_row.c013 := get_array_value (l_line_array, 13);      l_row.c014 := get_array_value (l_line_array, 14);      l_row.c015 := get_array_value (l_line_array, 15);      l_row.c016 := get_array_value (l_line_array, 16);      l_row.c017 := get_array_value (l_line_array, 17);      l_row.c018 := get_array_value (l_line_array, 18);      l_row.c019 := get_array_value (l_line_array, 19);      l_row.c020 := get_array_value (l_line_array, 20);      pipe row (l_row);    end if;    --将使用当前的扫描位置加上行的分割符号 来替换 上一次的扫描位置     l_last := l_current + length (l_line_separator);  end loop;  return;end clob_to_csv;

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:lob to csv
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址