博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
批量导出表数据到CSV文件
阅读量:5970 次
发布时间:2019-06-19

本文共 1971 字,大约阅读时间需要 6 分钟。

需求:把oracle数据库中符合条件的N多表。导出成csv文本文件。并以表名.csv为文件名称存放。

实现:通过存储过程中UTL_FILE函数来实现。导出的csv文件放入提前创建好的directory中。

用法:使用下面命令数据预运行的SQL脚本

SELECT 'EXEC sql_to_csv(''select * from ' ||T.TABLE_NAME ||

''',''OUT_PUT_CSV''' || ',''ODS_MDS.' || T.TABLE_NAME ||

'.csv'');'
FROM user_TABLES T

脚本说明:sql_to_csv 存储过程名。out_put_csv数据库文件夹名称;ODS_MDS提前定义的schema名称;

存储过程代码例如以下:

CREATE OR REPLACE PROCEDURE CHENQY.SQL_TO_CSV( P_QUERY IN VARCHAR2, -- PLSQL文 P_DIR IN VARCHAR2, -- 导出的文件放置文件夹 P_FILENAME IN VARCHAR2 -- CSV名 ) IS  L_OUTPUT UTL_FILE.FILE_TYPE;  L_THECURSOR INTEGER DEFAULT DBMS_SQL.OPEN_CURSOR;  L_COLUMNVALUE VARCHAR2(4000);  L_STATUS INTEGER;  L_COLCNT NUMBER := 0;  L_SEPARATOR VARCHAR2(1);  L_DESCTBL DBMS_SQL.DESC_TAB;  P_MAX_LINESIZE NUMBER := 32000;BEGIN  --OPEN FILE  L_OUTPUT := UTL_FILE.FOPEN(P_DIR, P_FILENAME, 'W', P_MAX_LINESIZE);  --DEFINE DATE FORMAT  EXECUTE IMMEDIATE 'ALTER SESSION SET NLS_DATE_FORMAT=''YYYY-MM-DD HH24:MI:SS''';  --OPEN CURSOR  DBMS_SQL.PARSE(L_THECURSOR, P_QUERY, DBMS_SQL.NATIVE);  DBMS_SQL.DESCRIBE_COLUMNS(L_THECURSOR, L_COLCNT, L_DESCTBL);  --DUMP TABLE COLUMN NAME  FOR I IN 1 .. L_COLCNT LOOP    UTL_FILE.PUT(L_OUTPUT,L_SEPARATOR || '"' || L_DESCTBL(I).COL_NAME || '"'); --输出表字段    DBMS_SQL.DEFINE_COLUMN(L_THECURSOR, I, L_COLUMNVALUE, 4000);    L_SEPARATOR := ',';  END LOOP;  UTL_FILE.NEW_LINE(L_OUTPUT); --输出表字段  --EXECUTE THE QUERY STATEMENT  L_STATUS := DBMS_SQL.EXECUTE(L_THECURSOR);   --DUMP TABLE COLUMN VALUE  WHILE (DBMS_SQL.FETCH_ROWS(L_THECURSOR) > 0) LOOP    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 || '"' ||                   TRIM(BOTH ' ' FROM REPLACE(L_COLUMNVALUE, '"', '""')) || '"');      L_SEPARATOR := ',';    END LOOP;    UTL_FILE.NEW_LINE(L_OUTPUT);  END LOOP;  --CLOSE CURSOR  DBMS_SQL.CLOSE_CURSOR(L_THECURSOR);  --CLOSE FILE  UTL_FILE.FCLOSE(L_OUTPUT);EXCEPTION  WHEN OTHERS THEN    RAISE;END; /

转载地址:http://rswox.baihongyu.com/

你可能感兴趣的文章
The absolute uri: http://java.sun.com/jsp/jstl/core cannot be resolved in either web.xml or the jar
查看>>
redis主从配置<转>
查看>>
karma如何与测试框架合作2之webpack
查看>>
10分钟搭建MySQL Binlog分析+可视化方案
查看>>
vmware虚拟机配置串口
查看>>
小型自动化运维--expect脚本之传递函数
查看>>
Nsrp实现juniper防火墙的高可用性【HA】!
查看>>
oracle11g 安装在rhel5.0笔记
查看>>
解决Lync 2013演示PPT提示证书问题的多种方法
查看>>
bootloader功能介绍/时钟初始化设置/串口工作原理/内存工作原理/NandFlash工作原理...
查看>>
C++ 构造函数与析构函数
查看>>
ssh免密码登录
查看>>
Linux下Django环境安装
查看>>
如何在指定的内容中找出指定字符串的个数
查看>>
我的友情链接
查看>>
浅谈如何用We7站群平台打造垂直性政务网站
查看>>
我的友情链接
查看>>
Spring MVC请求处理流程分析
查看>>
Web应用工作原理、动态网页技术
查看>>
EXCEL工作表保护密码破解 宏撤销保护图文教程
查看>>