Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1184543
  • 博文数量: 398
  • 博客积分: 10110
  • 博客等级: 上将
  • 技术积分: 4055
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-23 20:01
个人简介

新博客http://www.cnblogs.com/zhjh256 欢迎访问

文章分类

全部博文(398)

文章存档

2012年(1)

2011年(41)

2010年(16)

2009年(98)

2008年(142)

2007年(100)

我的朋友

分类: Oracle

2009-06-04 16:44:42

oracle导出文本文件数据的方法貌似只有sqlplus的spool命令,要定期导出需要借助os的计划任务之类的,不过10g中dbms_schedualr也支持直接掉os批处理文件。
 
文件名动态命名为当前日期。
 
例如,
--bat文件
D:\oracle92\bin\sqlplus @C:\zhjh\demo.sql
 
--C:\zhjh\demo.sql
SET NEWPAGE NONE
SET HEADING OFF
SET SPACE 0
SET PAGESIZE 0
SET TRIMOUT ON
SET TRIMSPOOL ON
SET LINESIZE 2500
set colsep '|'
set feedback off
set echo off
SET VERIFY OFF
column v_date new_value filename;
select to_char(sysdate,'yyyymmdd') || '.dat' v_date from dual;
spool c:\&&filename
select * from scott.emp;
spool off;
 
--执行后
      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
然后再用任何调度工具调度即可。
 
海量数据导出的话可以使用并行导出,用条件区分开,这样可以提高导出性能。
 
在导入teradta数据库时,使用fastload即可,并且该工具支持一次从多个文件导入。
阅读(2029) | 评论(2) | 转发(0) |
给主人留下些什么吧!~~

aqcjsy12009-07-29 13:45:10

可使用任何一种任务调度工具,如crontab或任务计划

chinaunix网友2009-07-16 22:24:01

想问一下,如何让fastload自动执行文本数据导入td