SQLLoader6(一个或多个数据文件按条件导入不同的表)
测试一
1、创建表:
SQL> create table tab_b(col1 varchar2(2), col2 number(2)); 表已创建。 SQL> create table tab_a(col1 varchar2(2), col2 number(2)); 表已创建。 SQL> COMMIT; 提交完成。
2、数据文件:test.txt
A 1
A 2
A 3
B 3
B 2
B 1
3、控制文件:testSqlLdr2.ctl
LOAD DATA
INFILE 'D:\oracletest\test.txt'
DISCARDFILE 'D:\oracletest\testSqlLdr2.dsc'
REPLACE
INTO TABLE TAB_A
WHEN COL1="A"
(COL1 position(1:1),COL2 position(3:4))
INTO TABLE TAB_B
WHEN COL1="B"
(COL1 position(1:1),COL2 position(3:4))
4、执行导入
D:\oracletest>sqlldr scott/tiger@orcl control=D:\oracletest\testSqlLdr2.ctl SQL*Loader: Release 11.2.0.1.0 - Production on 星期日 11月 30 21:27:16 2014 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. 达到提交点 - 逻辑记录计数 5
达到提交点 - 逻辑记录计数 6
5、查看结果:
SQL> SELECT * FROM TAB_A; CO COL2
-- ----------
A 1
A 2
A 3 SQL> SELECT * FROM TAB_B; CO COL2
-- ----------
B 3
B 2
B 1
测试二
1、创建测试表
SQL> CREATE TABLE EMP_DEPT10 AS SELECT * FROM EMP WHERE DEPTNO=10 AND 1=2; 表已创建。 SQL> CREATE TABLE EMP_DEPT20 AS SELECT * FROM EMP WHERE DEPTNO=20 AND 1=2; 表已创建。 SQL> CREATE TABLE EMP_DEPT30 AS SELECT * FROM EMP WHERE DEPTNO=30 AND 1=2; 表已创建。 SQL> SELECT * FROM EMP_DEPT10; 未选定行 SQL> SELECT * FROM EMP_DEPT20; 未选定行 SQL> SELECT * FROM EMP_DEPT30; 未选定行 SQL>
2、数据文件
--D:\oracletest\test1.txt
1 7782 CLARK MANAGER 7839 1981-06-09 2450 0 10
1 7839 KING PRESIDENT 1111 1981-11-17 5000 0 10
1 7934 MILLER CLERK 7782 1982-01-23 1300 0 10
--D:\oracletest\test2.txt
2 7369 SMITH CLERK 7902 1980-12-17 800 0 20
2 7566 JONES MANAGER 7839 1981-04-02 2975 0 20
2 7788 SCOTT ANALYST 7566 1987-04-19 3000 0 20
2 7876 ADAMS CLERK 7788 1987-05-23 1100 0 20
2 7902 FORD ANALYST 7566 1981-12-03 3000 0 20
--D:\oracletest\test3.txt
3 7499 ALLEN SALESMAN 7698 1981-02-20 1600 300 30
3 7521 WARD SALESMAN 7698 1981-02-22 1250 500 30
3 7654 MARTIN SALESMAN 7698 1981-09-28 1250 1400 30
3 7698 BLAKE MANAGER 7839 1981-05-01 2850 123 30
3 7844 TURNER SALESMAN 7698 1981-09-08 1500 0 30
3 7900 JAMES CLERK 7698 1981-12-03 950 0 30
3、控制文件
LOAD DATA
INFILE 'D:\oracletest\test1.txt'
INFILE 'D:\oracletest\test2.txt'
INFILE 'D:\oracletest\test3.txt'
BADFILE 'D:\oracletest\testSqlLdr3.bad'
DISCARDFILE 'D:\oracletest\testSqlLdr3.dsc'
REPLACE
INTO TABLE EMP_DEPT10
WHEN FLAG="1" --用flag做标记
FIELDS TERMINATED BY WHITESPACE
(FLAG FILLER POSITION(1), --一定要指定POSITION(1)不能省略,只有指定POSITION(1)才能决定数据从第一列开始读取,否则会出现空值或数据列错位。
EMPNO,ENAME,JOB,MGR,HIREDATE DATE "YYYY-MM-DD" ,SAL,COMM,DEPTNO)
INTO TABLE EMP_DEPT20
WHEN FLAG="2"
FIELDS TERMINATED BY WHITESPACE
(FLAG FILLER POSITION(1),
EMPNO,ENAME,JOB,MGR,HIREDATE DATE "YYYY-MM-DD",SAL,COMM,DEPTNO)
INTO TABLE EMP_DEPT30
WHEN FLAG="3"
FIELDS TERMINATED BY WHITESPACE
(FLAG FILLER POSITION(1),
EMPNO,ENAME,JOB,MGR,HIREDATE DATE "YYYY-MM-DD",SAL,COMM,DEPTNO)
4、执行导入命令
D:\oracletest>sqlldr scott/tiger@orcl control=D:\oracletest\testSqlLdr3.ctl SQL*Loader: Release 11.2.0.1.0 - Production on 星期日 11月 30 22:32:49 2014 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. 达到提交点 - 逻辑记录计数 2
达到提交点 - 逻辑记录计数 3
达到提交点 - 逻辑记录计数 7
达到提交点 - 逻辑记录计数 8
达到提交点 - 逻辑记录计数 13
达到提交点 - 逻辑记录计数 14
5、检查导入结果
SQL> select * from emp_dept10; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ---------- ---------- ---------- ----------
7782 CLARK MANAGER 7839 1981-06-09 2450 0 10
7839 KING PRESIDENT 1111 1981-11-17 5000 0 10
7934 MILLER CLERK 7782 1982-01-23 1300 0 10 SQL> select * from emp_dept20; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ---------- ---------- ---------- ----------
7369 SMITH CLERK 7902 1980-12-17 800 0 20
7566 JONES MANAGER 7839 1981-04-02 2975 0 20
7788 SCOTT ANALYST 7566 1987-04-19 3000 0 20
7876 ADAMS CLERK 7788 1987-05-23 1100 0 20
7902 FORD ANALYST 7566 1981-12-03 3000 0 20 SQL> select * from emp_dept30; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ---------- ---------- ---------- ----------
7499 ALLEN SALESMAN 7698 1981-02-20 1600 300 30
7521 WARD SALESMAN 7698 1981-02-22 1250 500 30
7654 MARTIN SALESMAN 7698 1981-09-28 1250 1400 30
7698 BLAKE MANAGER 7839 1981-05-01 2850 123 30
7844 TURNER SALESMAN 7698 1981-09-08 1500 0 30
7900 JAMES CLERK 7698 1981-12-03 950 0 30 已选择6行。
SQLLoader6(一个或多个数据文件按条件导入不同的表)的更多相关文章
- Tableau学习Step2一数据文件的读取与统计图、表的概述
Tableau学习Step2一数据文件的读取与统计图.表的概述 本文首发于博客冰山一树Sankey,去博客浏览效果更好. 一. 前言 本教程通过一个案例从浅到深来学习Tableau知识 案例概述: 二 ...
- 记一个手游app数据文件的破解
出于一些非常猥琐的须要,同一时候自己也想做一些新奇的尝试,周末用了大半天时间破解了某款手游的数据文件. 过程比我预想的要顺利,主要原因还是我们开发者的懈怠.咳咳. 步骤例如以下: 下载安装包,解压,发 ...
- Oracle-11g 从表空间删除数据文件
从表空间删除数据文件前提条件 如果欲从表空间中删除数据文件,那么该数据文件必须为空,否则将报出"ORA-03262: the file is non-empty"的错误. 从表 ...
- 浅谈Oracle中物理结构(数据文件等。。。)与逻辑结构(表空间等。。。。。)
初始Oracle时很难理解其中的物理结构和逻辑结构,不明白内存中和硬盘中文件的区别和联系,我也是初学Oracle,这里就简单的谈谈我我看法. 首先,你需要明白的一点是:数据库的物理结构是由数据库的操作 ...
- Oracle的表空间和数据文件
一. 概念 表空间:是一个或多个数据文件的逻辑集合 表空间逻辑存储对象: 永久段-->如表与索引 临时段-->如临时表数据与排序段 回滚段-->用于事物回滚或闪回内存的撤销数据 表空 ...
- 关于oracle修复控制文件与数据文件不一致的问题----
本小菜鸟周末鼓捣数据库关于rman恢复与备份方面的实验,结果不知道哪根筋搭错了,手一哆嗦,做了不知道什么操作,就出现了数据库打不开的严重状态,只能开启到mount状态,但是切换到open状态时就会报错 ...
- 管理表空间和数据文件<六>
数据库管理 -- 管理表空间和数据文件 介绍 表空间是数据库的逻辑组成部分.从物理上讲,数据库数据存放在数据文件中:从逻辑上讲,数据库则是存放在表空间中,表 空间由一个或多个数据文件组成. 数据库 ...
- 巧用AWK处理二进制数据文件
AWK是Unix下的一款功能强大的文本格式化和抽取工具.利用这个工具,可以对复杂的文本文件进行整理,提取其中的全部或者部分数据,按照需要的格式予以显示.需要说明的是,AWK的强大功能只针对纯文本文件. ...
- 【转】Oracle 表空间与数据文件
--============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...
随机推荐
- html5图片标签与属性
标记: 标 记 说 明 <lmg> 图像 <Map> 图像映射 <Area> 图像映射中定义区域 <lmg>标记属性: 属 性 说 明 Src ...
- RMAN之进入RMAN(转)
通过RMAN的方式不论要备份还是要恢复,都必须先启动实例并加载数据库. SQL> shutdown immediate数据库已经关闭.已经卸载数据库.ORACLE 例程已经关闭. C:\User ...
- oracle数据库事务相关【weber出品必属精品】
事务的概念:事务:一个事务由一组构成一个逻辑操作的DML语句组成 事务有开始有结束,事务以DML语句开始,以Conmmit和Rollback结束.以下情况会使得事务结束: 1. 执行COMMIT 或者 ...
- linux shell脚本连接oracle查询数据插入文件和日志文件中
#!/bin/sh sqlplus "用户名/密码@数据库"<<EOF 或者只有一个库的 :sqlplus "用户名/密码"<<EOF ...
- MFC中函数名前加 :: 原因
在开发MFC之前,开发的是以AFx(Application Frameworks,x是没有什么意义的)开头的一些函数.但是那个时候开发的函数并没有进行封装,但是有很多很有用的函数.最后AFx开发失败, ...
- C语言中固定大小的数据类型的输入和输出
在使用C语言时,对数据的大小要求比较严格时,例如要使用32位的整数类型,这时要使用 int32_t,无论平台如何变化,数据大小仍然是32位,固定位数的数据类型还有 uint32_t.uint64_t ...
- WinPython安装问题(pyzmq问题导致)
最近yvivid安装WinPython-32bit-3.4.4.1, 安装后,运行spyder运行时出现如下错误, Traceback (most recent call last): File &q ...
- apache用户认证、默认主机、301跳转
我更正论坛一个同学帖子(今天坑我一下午):原文http://www.apelearn.com/bbs/foru ... 3%BB%A7%C8%CF%D6%A4 apache用户认证.默认主机.301跳 ...
- some logo.
发现一些logo , 储存在这里
- mysql 5.7 内存使用监控
5.7 中的performance_schema 已经有能力监控mysql 的内存使用情况了,对于这一点也是要通过instrument 来实现的,由于内存这一块没有对应的consumer 所以只要 配 ...