oracle文件读取,用oracle utl_file包读取数据写入文件

这是一个PL/SQL函数,用于根据用户输入的SQL查询、分隔符、目录和文件名导出数据库数据到指定目录下的文本文件。函数首先计算查询结果的总数,然后按指定数量分批写入文件,确保数据完整导出。该函数适用于批量数据抽取和存储过程中的数据导出操作。
摘要由CSDN通过智能技术生成

create or replace directory MY_DIR as '/usr/test/';

create or replace function f_exportTxt(

--传入参数

i_query in varchar2,

i_separator in varchar2,

i_dir in varchar2,

i_filename in varchar2

) return number

is

/**

** 函数名:f_exportTxt

** 参数:1.i_query 查询sql语句; 2.i_separator 分隔符,默认为',' ;

**      3.i_dir存放目录; 4.i_filename文件名,默认在文件名前加上yyyymmddhh24mi

** 返回: 大于等于0即为写入文件记录数,负为异常

** 功能: 用户数据抽取,并生成文件到指定目录下

** 备注:

** 作者:lingo

** 修改日期:2010-04-15

**/

--定义参数

v_file utl_file.file_type;

v_theCursor integer default dbms_sql.open_cursor;

v_columnValue varchar2(2000); --临时(列值)

v_colCnt number default 0; --列总数

v_separator varchar2(10) default ',';--分隔符,默认为#@

v_cnt number default 0;  --记录总数

v_filename varchar2(100);--时间

v_status integer;--执行SQL后返回状态值

v_count number default 10000 ; --每次查询的数量,大于该数量则多次读取数据到游标

v_tmp number ;--临时(总记录数,通过SQL统计算出,假如v_cnt不等于v_tmp,则导出有误)

v_sql varchar2(2000) ; --组合sql语句

v_loops number ; --循环次数

begin

--select to_char(sysdate,'yyyymmddhh24mi') into v_filename from dual; --取时间年月日时分做文件名前缀

v_filename :='';

v_filename := v_filename||i_filename ; --组建文件名

v_sql := 'select count(''x'') from (' ||i_query||')' ;--统计总数

execute immediate v_sql into v_tmp;

select trunc(v_tmp/v_count) into v_loops from dual ; --循环次数

if mod(v_tmp,v_count) > 0 then

v_loops := v_loops+1;

end if;

v_file := utl_file.fopen(i_dir,v_filename,'W'); --打开文件

for i in 1 .. v_loops loop

v_sql := 'select * from ( select m.*,rownum r fr

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值