动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息



本月文章推荐
.数据表中数据的管理.
.中大与甲骨文创建供应链管理研究.
.Oracle数据库常见问题答疑.
.必须要熟悉的V$视图.
.使用Oracle9i数据库的注意事项.
.ActualTest Oracle 1Z0-301 v05..
.Oracle中对两个数据表交集的查询.
.oracle10g初始化参数说明一.
.Oracle 9i索引.
.使自己暂时脱离 root 的身份.
.在Oracle9i中Oracle DATA计算时间.
.ORACLE的客户端如何连接到数据库.
.Oracle Database 10 g : 为 DBA .
.ORACLE数据库对象统计分析技术应.
.在Oracle中找出重复的纪录的方法.
.Oracle数据库技术(30).
.Oracle数据字典与动态性能表的相.
.本人编写的两个Oracle的帮助小工.
.给 vi 初学者(1).
.通过PL/SQL访问Web Services.

使用UTL_FILE转储数据为逗号分隔符文件

发表日期:2008-2-9 |



  Tom写过这样一个函数用于把数据转储为逗号分隔符文件,看到很多人问类似的问题,转载这里供参考。
  
  注重,UTL_FILE使用的Directory,需要你预先创建,具体可以参考Using Create directory & UTL_FILE in Oracle
  
  create or replace function dump_csv( p_query   in varchar2,
                     p_separator in varchar2
                            default ',',
                     p_dir    in varchar2 ,
                     p_filename in varchar2 )
  return number
  AUTHID CURRENT_USER
  is
    l_output    utl_file.file_type;
    l_theCursor   integer default dbms_sql.open_cursor;
    l_columnValue  varchar2(2000);
    l_status    integer;
    l_colCnt    number default 0;
    l_separator   varchar2(10) default '';
    l_cnt      number default 0;
  begin
    l_output := utl_file.fopen( p_dir, p_filename, 'w' );
  
    dbms_sql.parse( l_theCursor, p_query, dbms_sql.native );
  
    for i in 1 .. 255 loop
      begin
        dbms_sql.define_column( l_theCursor, i,
                    l_columnValue, 2000 );
        l_colCnt := i;
      exception
        when others then
          if ( sqlcode = -1007 ) then exit;
          else
            raise;
          end if;
      end;
    end loop;
  
    dbms_sql.define_column( l_theCursor, 1, l_columnValue,
                2000 );
  
    l_status := dbms_sql.execute(l_theCursor);
  
    loop
      exit when ( dbms_sql.fetch_rows(l_theCursor) <= 0 );
      l_separator := '';
      for i in 1 .. l_colCnt loop
        dbms_sql.column_value( l_theCursor, i,
                    l_columnValue );
        utl_file.put( l_output, l_separator
                    l_columnValue );
        l_separator := p_separator;
      end loop;
      utl_file.new_line( l_output );
      l_cnt := l_cnt+1;
    end loop;
    dbms_sql.close_cursor(l_theCursor);
  
    utl_file.fclose( l_output );
    return l_cnt;
  end dump_csv;
  /
  
  
  以下是使用样例:
  
  [oracle@jumper tmp]$ sqlplus "/ as sysdba"
  
  SQL*Plus: Release 9.2.0.4.0 - ProdUCtion on Fri May 13 15:04:41 2005
  
  Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
  
  
  Connected to:
  Oracle9i Enterprise Edition Release 9.2.0.4.0 - Production
  With the Partitioning option
  JServer Release 9.2.0.4.0 - Production
  
  SQL> select dump_csv('select * from scott.emp',',','/tmp','emp.csv') from dual;
  
  DUMP_CSV('SELECT*FROMSCOTT.EMP',',','/TMP','EMP.CSV')
  -----------------------------------------------------
                            14
  SQL> !
more /tmp/emp.csv
  7369,SMITH,CLERK,7902,17-DEC-80,800,,20
  7499,ALLEN,SALESMAN,7698,20-FEB-81,1600,300,30
  7521,WARD,SALESMAN,7698,22-FEB-81,1250,500,30
  7566,JONES,MANAGER,7839,02-APR-81,2975,,20
  7654,MARTIN,SALESMAN,7698,28-SEP-81,1250,1400,30
  7698,BLAKE,MANAGER,7839,01-MAY-81,2850,,30
  7782,CLARK,MANAGER,7839,09-JUN-81,2450,,10
  7788,SCOTT,ANALYST,7566,19-APR-87,3000,,20
  7839,KING,PRESIDENT,,17-NOV-81,5000,,10
  7844,TURNER,SALESMAN,7698,08-SEP-81,1500,0,30
  7876,ADAMS,CLERK,7788,23-MAY-87,1100,,20
  7900,JAMES,CLERK,7698,03-DEC-81,950,,30
  7902,FORD,ANALYST,7566,03-DEC-81,3000,,20
  7934,MILLER,CLERK,7782,23-JAN-82,1300,,10
上一篇:RMAN和EXP/IMP转移数据的实测比较 人气:321
下一篇:使用Oracle9i的新特性Flashback Query恢复误删除数据 人气:402
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-25 WikyBlog v1.7.0.1 多国语言版
2008-7-25 乐彼网上开店系统(56770 Eshop)
2008-7-25 赛特网站管理系统sitecms v3.6.0
2008-7-25 Modoer多功能点评系统 v1.0.1 Bu
2008-7-25 Shangducms Teamsuit! v1.1.0 开
2008-7-25 幻影动漫网视频系统(Ppdong) v1.
2008-7-25 acteecompany企业网站建设系统 v
2008-7-25 恒浪整合管理系统 ims v4.1 ACCE
2008-7-25 艺术图库系统 v1.0 beta
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号