oracle utl_file包读取数据的实例
创始人
2024-07-18 00:00:29
0

oracle utl_file包相信大家都有一定的了解,下面为您介绍的是oracle utl_file包读取数据的实现方法,如果您对oracle utl_file包方面感兴趣的话,不妨一看。

  1. create or replace directory MY_DIR as '/usr/test/';  
  2. create or replace function f_exportTxt(  
  3.   --传入参数  
  4.   i_query in varchar2,  
  5.   i_separator in varchar2,  
  6.   i_dir in varchar2,  
  7.   i_filename in varchar2  
  8. ) return number  
  9. is  
  10.   /**  
  11.   ** 函数名:f_exportTxt  
  12.   ** 参数:1.i_query 查询sql语句; 2.i_separator 分隔符,默认为',' ;  
  13.   **      3.i_dir存放目录; 4.i_filename文件名,默认在文件名前加上yyyymmddhh24mi  
  14.   ** 返回: 大于等于0即为写入文件记录数,负为异常  
  15.   ** 功能: 用户数据抽取,并生成文件到指定目录下  
  16.   ** 备注:  
  17.   ** 作者:lingo  
  18.   ** 修改日期:2010-04-15  
  19.   **/  
  20.   --定义参数  
  21.   v_file utl_file.file_type;  
  22.   v_theCursor integer default dbms_sql.open_cursor;  
  23.   v_columnValue varchar2(2000); --临时(列值)  
  24.   v_colCnt number default 0; --列总数  
  25.   v_separator varchar2(10) default ',';--分隔符,默认为#@  
  26.   v_cnt number default 0;  --记录总数  
  27.   v_filename varchar2(100);--时间  
  28.   v_status integer;--执行SQL后返回状态值  
  29.   v_count number default 10000 ; --每次查询的数量,大于该数量则多次读取数据到游标  
  30.   v_tmp number ;--临时(总记录数,通过SQL统计算出,假如v_cnt不等于v_tmp,则导出有误)  
  31.   v_sql varchar2(2000) ; --组合sql语句  
  32.   v_loops number ; --循环次数  
  33. begin  
  34.   --select to_char(sysdate,'yyyymmddhh24mi') into v_filename from dual; --取时间年月日时分做文件名前缀  
  35.   v_filename :='';  
  36.   v_filename := v_filename||i_filename ; --组建文件名  
  37.   v_sql := 'select count(''x'') from (' ||i_query||')' ;--统计总数  
  38.   execute immediate v_sql into v_tmp;  
  39.   select trunc(v_tmp/v_count) into v_loops from dual ; --循环次数  
  40.   if mod(v_tmp,v_count) > 0 then  
  41.     v_loops := v_loops+1;  
  42.   end if;  
  43.   v_file := utl_file.fopen(i_dir,v_filename,'W'); --打开文件  
  44.   for i in 1 .. v_loops loop  
  45.       v_sql := 'select * from ( select m.*,rownum r fr ......   

 

 

 

 

【编辑推荐】

Oracle创建用户及删除用户的实例

Oracle物化视图创建全过程

ORACLE创建实例的过程

oracle时间加减的语句写法

教您如何检查oracle死锁

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...