Orcale 数据加载
CSV 逗号分隔值格式文件
1,若要加载的文件不是CSV格式,可以修改数据文件,用分隔符来替换逗号;也可以修改控制文件,将FIELDS TERMINATED BY的值改为实际的分隔符。
eg, 要向scott.bonus表插入数据 **.dat.
1. SMITH,CLEAK,3904
2. ALLEN,"SALER,M",2891
3. WARD,"SALER,""S""",3128
4. KING,PRESIDENT,2523
LOAD DATA
INFILE **.dat
TRUNCATE INTO TABLE BONUS
FIELDS TERMINATED BY "," OPTIONALLOY ENCLOSED BY '"'
(ENAME, JOB, SAL)
save as ldr_case2.ctl
运行SQLLDR:
> sqlldr scott/tiger control= ldr_case2.ctl
2,若数据文件没有分隔符,但是定长字符串。 使用position 关键字来指定列的开始和结束位置。 如:
position(7:15 )从第7个字符开始截止到第15个字符作为ENAME列的列值。
position(*+2:15) *号代表相对偏移量,从上次结束的位置+2的地方开始。
position(*)char(9): 这种方式 只需为第一列指定开始位置,其他列只需要指定列长度即可。
1. LOAD DATA
2. INFILE ldr_case3.dat
3. TRUNCATE INTO TABLE BONUS
4. (
5. ENAME position(1:5),
6. JOB position(7:15),
7. SAL position(17:20)
8.)
SQL> DESC BONUS; //查看表结构
3,若数据文件中的列少于将要导入的表的列。在控制文件中加入 COMM “0” 即可。
4,若数据文件中的列多于将要导入的表的列,
方式一: 修改数据文件,将多余的数据删除(使用于小数据量)
方式二: 如1. SMITH 7369 CLERK 800 20
2. ALLEN 7499 SALESMAN 1600 30
希望导入1、3、4 列而跳过2、5列,

5,提供多个数据文件,要导入同一张表
指定多个INFILE参数即可。2前提是提供的数据文件中的数据存放格式必须完全相同。
6,同一个数据文件要导入不同的表,使用WHEN关键字。
需求是将以MGR开头的记录导入MANAGER表,以BON开头的记录导入BONUS表,其他记录存入废弃文件中,

注:控制文件中的WHEN逻辑判断不支持OR关键字,如果判断条件有多个,使用AND连接。
7,数据前N行不想导入。
可以使用文本工具修改数据文件,linux下可以通过tail命令实现。 若不想修改数据文件,则 SKIP参数。
SQL> SQLLDR SCOTT/TIGER CONTROL=LDR_CASE10.CTL SKIP=3 前3行不导入。
若 导入 4到6行, 则
SQL> SQLLDR SCOTT/TIGER CONTROL=LDR_CASE10.CTL SKIP=4 LOAD=6
8,要加载的数据中有换行符,复杂, 要sqlldr指明什么时候才进行换行操作。
eg手工指定换行符, 数据文件中的换行符不是标准的换行标志。而是用户自定义的一个标志字符。这种情况下”
LOAD DATA
INFILE ldr case11.dat
TRUNCATE INTO TABLE manager
FIELDS TERMINATED BY ","
(MGRNO MANAME,JOUB,TRMAK,
REMARK "replace(:remark, '\\n',chr(10))")
理论知识说完,实践下。
首先 cmd-> sqlplus dabook/dabook_localhost
连接dabook,
create table manager;

编辑 testData.csv 文件, 存放在E:\下。
12,Smith,manager,3600
13,Paul ,coder,3000
14,Lynn,tester,2000
编辑control文件:TEST01.CTL
LOAD DATA
INFILE 'E:\testData.csv'
INTO TABLE MANAGER
FIELDS TERMINATED BY "," OPTIONALLY ENCLOSED BY '"'
(MGRNO,MNAME,JOB,REMARK)
使用show parameter control_files;命令查看已有的control文件。为了找到control的路径。一般都放在一起比较好吧。

cmd> sqlldr system/D199033 control= E:\APP\DINGQI\ORADATA\TEST\DABOOK\TEST1.CTL 导入数据

。
在去select 下 ,发现数据就进去了!

PS:贴上我的Oracle安装地址

。 。。
Orcale 数据加载的更多相关文章
- AE数据加载
1. 数据加载问题: 任何系统都离不开数据的加载,下边就AE中几种常用的数据加载做一个列举.以便查阅: 1.加载个人数据库 个人数据库是保存在Access中的数据库.其加载方式有两种:通过名字和通过属 ...
- ScrollView嵌套ListView,GridView数据加载不全问题的解决
我们大家都知道ListView,GridView加载数据项,如果数据项过多时,就会显示滚动条.ScrollView组件里面只能包含一个组件,当ScrollView里面嵌套listView,GridVi ...
- python多种格式数据加载、处理与存储
多种格式数据加载.处理与存储 实际的场景中,我们会在不同的地方遇到各种不同的数据格式(比如大家熟悉的csv与txt,比如网页HTML格式,比如XML格式),我们来一起看看python如何和这些格式的数 ...
- flask+sqlite3+echarts3+ajax 异步数据加载
结构: /www | |-- /static |....|-- jquery-3.1.1.js |....|-- echarts.js(echarts3是单文件!!) | |-- /templates ...
- Entity Framework关联查询以及数据加载(延迟加载,预加载)
数据加载分为延迟加载和预加载 EF的关联实体加载有三种方式:Lazy Loading,Eager Loading,Explicit Loading,其中Lazy Loading和Explicit Lo ...
- JQuery插件:遮罩+数据加载中。。。(特点:遮你想遮,罩你想罩)
在很多项目中都会涉及到数据加载.数据加载有时可能会是2-3秒,为了给一个友好的提示,一般都会给一个[数据加载中...]的提示.今天就做了一个这样的提示框. 先去jQuery官网看看怎么写jQuery插 ...
- 如何评估ETL的数据加载时间
简述如何评估大型ETL数据加载时间. 答:评估一个大型的ETL的数据加载时间是一件很复杂的事情.数据加载分为两类,一类是初次加载,另一类是增量加载. 在数据仓库正式投入使用时,需要进行一次初次加载,而 ...
- 浅谈Entity Framework中的数据加载方式
如果你还没有接触过或者根本不了解什么是Entity Framework,那么请看这里http://www.entityframeworktutorial.net/EntityFramework-Arc ...
- 实现虚拟模式的动态数据加载Windows窗体DataGridView控件 .net 4.5 (一)
实现虚拟模式的即时数据加载Windows窗体DataGridView控件 .net 4.5 原文地址 :http://msdn.microsoft.com/en-us/library/ms171624 ...
随机推荐
- k8s入坑之路(5)kube-apiserver详解
API Server kube-apiserver 是 Kubernetes 最重要的核心组件之一,主要提供以下的功能 提供集群管理的 REST API 接口,包括认证授权.数据校验以及集群状态变更等 ...
- JMeter源码导入到Intellij IDEA (八)
亲测:jmeter源码导入Intellij IDEA,导入,编译,运行! 一.环境:windows10操作系统,jdk1.8,Intellij IDEA 2018.3,jmeter5.0 下载jmet ...
- loadRunner12 设置关联 获取服务端动态数据
关联:服务器返回给客户端一些动态变化的值,客户端用这些值去访问服务器,不能把这些值写死在脚本里面,而应该存放在一个变量里面. 在脚本回放过程中,客户端发出请求,通过关联函数所定义的左右边界值(也就是关 ...
- 第40篇-JNIEnv和JavaVM
下面介绍2个与JNI机制相关的类型JNIEnv和JavaVM. 1.JNIEnv JNIEnv一般是是由虚拟机传入,而且与线程相关的变量,也就说线程A不能使用线程B的JNIEnv.而作为一个结构体,它 ...
- Unicode、UTF-8、UTF-16 终于懂了
计算机起源于美国,上个世纪,他们对英语字符与二进制位之间的关系做了统一规定,并制定了一套字符编码规则,这套编码规则被称为ASCII编码 ASCII 编码一共定义了128个字符的编码规则,用七位二进制表 ...
- c++学习笔记3(动态内存分配)
为了效率,需要按需去进行动态内存分配,在c中,可以用malloc去实现动态内存分配,而在c++中,则用new运算符去实现. 用法一:动态分配一个变量的存储空间 p=new T T为类型名 P则为T*类 ...
- python一对一教程:Computational Problems for Physics chapter 1 Code Listings
作者自我介绍:大爽歌, b站小UP主 ,直播编程+红警三 ,python1对1辅导老师 . 本博客为一对一辅导学生python代码的教案, 获得学生允许公开. 具体辅导内容为<Computati ...
- java 获得 微信 UserId
.... public String cs() throws Exception{ /*访问页面,服务器会得到 code(request.getParameter("code")) ...
- 虚拟化中虚拟机处理器核数与物理主机cpu的关系
vCPU,顾名思义,是虚拟CPU. 创建虚拟机时,需要配置vCPU资源. 因此vCPU是虚拟机的部件. 因此脱离VM,谈论vCPU是没有意义的.虚拟化管理系统如何调度vCPU,取决于系统内的虚拟机数目 ...
- DECODE 与CASE WHEN 的比较
1.DECODE 只有Oracle 才有,其它数据库不支持; 2.CASE WHEN的用法, Oracle.SQL Server. MySQL 都支持; 3.DECODE 只能用做相等判断,但是可以配 ...