oracle11G的数据装载的几种方式


数据装载

数据的装载:

?SQL*LOADER

?外部表

?导入/导出

SQL*LOADER:

SQL*LOADER是一个ORACLE工具,能够将数据从外部数据文件装载到数据库中。

运行SQL*LOADER的命令是sqlldr。

Sqlldr的两种使用方式:

1. 只使用一个控制文件,在这个控制文件中包含数据

2. 使用一个控制文件(作为模板) 和一个数据文件

一般采用第二种方式,数据文件可以是 CSV 文件、txt文件或者以其他分割符分隔的。

说明:操作类型 可用以下中的一值:

1) insert     --为缺省方式,在数据装载开始时要求表为空

2) append  --在表中追加新记录

3) replace  --删除旧记录(用 delete from table 语句),替换成新装载的记录

4) truncate --删除旧记录(用 truncate table 语句),替换成新装载的记录

通过spool来制作数据文件:--可以查询帮助文档的示例代码

SQL> spool /u01/app/oracle/test_data_loader/student.txt--开启spool导出数据文件

SQL> select id ||‘,‘ || name ||‘,‘ || age ||‘,‘ || inner_date from student;--导出数据

ID||‘,‘||NAME||‘,‘||AGE||‘,‘||INNER_DATE

--------------------------------------------------------------------------------

1,zhangsan,21,23-JAN-15

2,lisi,22,23-JAN-15

3,wangwu,23,23-JAN-15

SQL> spool off;--关闭

SQL> exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

[[email protected] test_data_loader]$ cat student.txt--可以查看到导出的数据记录

SQL> select id ||‘,‘ || name ||‘,‘ || age ||‘,‘ || inner_date from student;

ID||‘,‘||NAME||‘,‘||AGE||‘,‘||INNER_DATE

--------------------------------------------------------------------------------

1,zhangsan,21,23-JAN-15

2,lisi,22,23-JAN-15

3,wangwu,23,23-JAN-15

SQL> spool off;

写配置文件:

[[email protected] test_data_loader]$ vi student.ctl

[[email protected] test_data_loader]$ cat student.ctl

options(skip=4)--表示前面的四行

load data--导入数据

infile ‘student.txt‘--通过该文件导入数据

into table student--导入的表

insert--执行的是插入操作

fields terminated by ‘,‘--记录中的分割符

(

id char,--注意虽然表中是number类型,但是要写char类型

name char,

age char,

inner_date date nullif (inner_date = "null"))

[[email protected] test_data_loader]$

既然是insert操作所以:

SQL> truncate table student;--清空表,由于执行的是插入操作

Table truncated.

SQL> select * from student;

no rows selected

执行sqlldr操作:

[[email protected] test_data_loader]$ sqlldr hr/hr control= student.ctl log = student.log

SQL*Loader: Release 11.2.0.1.0 - Production on Fri Jan 23 23:11:08 2015

Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.

Commit point reached - logical record count 4

[[email protected] test_data_loader]$ cat student.log

SQL*Loader: Release 11.2.0.1.0 - Production on Fri Jan 23 23:11:08 2015

Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.

Control File:   student.ctl

Data File:      student.txt

Bad File:     student.bad

Discard File:  none specified

(Allow all discards)

Number to load: ALL

Number to skip: 4

Errors allowed: 50

Bind array:     64 rows, maximum of 256000 bytes

Continuation:    none specified

Path used:      Conventional

Table STUDENT, loaded from every logical record.

Insert option in effect for this table: INSERT

Column Name                  Position   Len  Term Encl Datatype

------------------------------ ---------- ----- ---- ---- ---------------------

ID                                  FIRST     *   ,       CHARACTER

NAME                                 NEXT     *   ,       CHARACTER

AGE                                  NEXT     *   ,       CHARACTER

INNER_DATE                           NEXT     *   ,       DATE DD-MON-RR

NULL if INNER_DATE = 0X6e756c6c(character ‘null‘)

Record 4: Rejected - Error on table STUDENT, column ID.

Column not found before end of logical record (use TRAILING NULLCOLS)

Table STUDENT:

3 Rows successfully loaded.

1 Row not loaded due to data errors.

0 Rows not loaded because all WHEN clauses were failed.

0 Rows not loaded because all fields were null.

Space allocated for bind array:                  66048 bytes(64 rows)

Read   buffer bytes: 1048576

Total logical records skipped:          4

Total logical records read:             4

Total logical records rejected:         1

Total logical records discarded:        0

Run began on Fri Jan 23 23:11:08 2015

Run ended on Fri Jan 23 23:11:08 2015

Elapsed time was:     00:00:00.10

CPU time was:         00:00:00.01

[[email protected] test_data_loader]$ sqlplus hr/hr

SQL*Plus: Release 11.2.0.1.0 Production on Fri Jan 23 23:13:14 2015

Copyright (c) 1982, 2009, Oracle.  All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> select * from student;

ID NAME                        AGE INNER_DATE

---------- -------------------- ---------- ------------

1 zhangsan                     21 23-JAN-15

2 lisi                         22 23-JAN-15

3 wangwu                       23 23-JAN-15

SQL> exit

外部表:

外部表中的数据不装入数据库中,数据库中只存储外部表的定义信息,实际的数据位于操作系统的平面文件中,

但是,可以在数据库中,像访问正常表那样,通过select语句来访问操作系统中的平面文件中所含有的数据。

外部表是只读的。

可以使用SQL,PL/SQL和JAVA访问外部表。

外表表分为2种:使用数据泵引擎生成的外部表、

SQL> create table student_re(re_id,re_name,re_age,re_inner_date)

organization external

(

type oracle_datapump--外部表生成方式是数据泵

default directory test_impdp_expdp--默认的路径

location(‘student.dmp‘)--通过路径和文件名生成外部表在操作系统的平面数据文件

)

parallel--并行

as

select * from student;  2    3    4    5    6    7    8    9   10

Table created.

SQL> !ls

student.dmp  STUENT_17109.log

SQL>  select * from stuent;

RE_ID RE_NAME                  RE_AGE RE_INNER_DAT

---------- -------------------- ---------- ------------

1 zhangsan                     21 23-JAN-15

2 lisi                         22 23-JAN-15

3 wangwu                       23 23-JAN-15

SQL>

根据文本文件创建的外部表。

SQL> spool student.txt

ID||‘,‘||NAME||‘,‘||AGE||‘,‘||INNER_DATE

--------------------------------------------------------------------------------

1,zhangsan,21,23-JAN-15

2,lisi,22,23-JAN-15

3,wangwu,23,23-JAN-15

SQL> exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

[[email protected] test_impdp_expdp]$ vi student.txt

[[email protected] test_impdp_expdp]$ sqlplus hr/hr

SQL*Plus: Release 11.2.0.1.0 Production on Sat Jan 24 00:05:18 2015

Copyright (c) 1982, 2009, Oracle.  All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> create table student_re_2--该外部表的名称下面列是外部表的建表语句,而上面通过数据泵的表是通过as select from tab来建立的。

2  (id number,name varchar2(20),age number(10),inner_date date)

3  organization external

4  ( type oracle_loader--外部文件方式

5    default directory test_impdp_expdp--默认的目录

6    access parameters--访问外部文件所遵守的格式

7    (

records delimited by newline--记录分隔符

fields terminated by ‘,‘--字段分隔符

8    ) location (‘student.txt‘)--位置

);  9   10   11

Table created.

SQL> select * from student_re_2;

ID NAME                        AGE INNER_DATE

---------- -------------------- ---------- ------------

1 zhangsan                     21 23-JAN-15

2 lisi                         22 23-JAN-15

3 wangwu                       23 23-JAN-15

SQL>

时间: 2024-10-14 09:53:15

oracle11G的数据装载的几种方式的相关文章

Android——数据存储(四种方式之一)SharedPrefereces

Android--数据存储(四种方式) 1.SharedPrefereces   轻量级.XML  存储文件名,数据保存在data/data/basepackage/shared_prefs/myopt.xml中   实例-收藏-记住密码自动登录 //一种轻量级的数据存储方式//通过KEY 存入数据--putxxxx(key,value) 取出数据--getxxxx(key  default)   2.读写SD卡  SD的根目录  适用于数据流读写 3.SQLite  轻量级.dp文件多用于手机

数据持久化的一种方式

/** *数据持久化的四种方式 * *1-------属性列表 * *2-------对象归档 * *3-------SQLite3 * *4-------Core Data * *下面是数据持久化的第一种方式-----写入文件 */ /** *写入文件思路 * *1-----获取需要写入的文件对象 * *2-----获取需要写入的文件对象的文件路径 * *3-----写入文件 * *4-----读取文件 */ NSString* string=@"Copyright (c) 2015年 妖精的

iOS数据存储的几种方式

iOS的数据存储是iOS应用开发的重要知识点: 关于这方面知识,网上有很多介绍,但对于代码层次的使用方式并未有系统全面介绍.此文章针对iOS稍熟悉的童鞋,需要对CoreData的原理有一定的了解.目前存储方式大概有以下几种: NSKeyedArchiver  适用简单数据加密 NSUserDefaults  适用配置参数 Write  文件操作,同NSKeyedArchiver SQLite3  操作较复杂,不建议使用. CoreData  取代SQLite3,但要遵循NSManagedObje

EDM营销之数据细分的五种方式

我们都知道,EDM营销的终极目的仍然是与目标客户群体实现联接,拉动销售业绩.内容是B2B邮件营销的重中之重,提供能够匹配客户真实需要的有效内容,即实现B2B个性化邮件营销,是B2B邮件营销成功的关键因素.怎样实现B2B领域的个性化邮件营销呢?首先需要对B2B客户进行数据细分.结合多年来在B2B邮件营销领域的诸多成功实战经验,下面来看看 Focussend营销团队在本期为B2B营销者奉上实现B2B个性化邮件营销的五种数据细分方式. 博文配图:关于EDM营销数据细分的五种方式 方式一:按职能细分 B

基于MVC4+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式

在基于MVC4+EasyUI的Web开发框架里面,大量采用了Jquery的方法,对数据进行请求或者提交,方便页面和服务器后端进行数据的交互处理.本文主要介绍利用Jquery处理数据交互的几种方式,包括获取数据并显示,插入新数据到服务器,更新数据,删除数据等操作. 1.利用Jquery获取数据并显示 为了顺利获取数据,我们需要保持页面端调用和服务器端保持一致,并相应的把数据转换或者封装为对象实体进行处理. 下面我们以一个简单的全国省份.全国城市.全国城市行政区的案例进行Demo代码的介绍.   总

基于MVC+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式

在基于MVC4+EasyUI的Web开发框架里面,大量采用了Jquery的方法,对数据进行请求或者提交,方便页面和服务器后端进行数据的交互处理.本文主要介绍利用Jquery处理数据交互的几种方式,包括获取数据并显示,插入新数据到服务器,更新数据,删除数据等操作. 1.利用Jquery获取数据并显示 为了顺利获取数据,我们需要保持页面端调用和服务器端保持一致,并相应的把数据转换或者封装为对象实体进行处理. 下面我们以一个简单的全国省份.全国城市.全国城市行政区的案例进行Demo代码的介绍.   总

QF——iOS中数据持久化的几种方式

数据持久化的几种方式: 一.属性列表文件: .plist文件是种XML文件.数组,字典都可以和它互相转换. 读取plist文件生成数组:plist——>NSArray 把数组写入plist文件:NSArray——>plist 二.NSUserDefaults: 它是单例的.通过[NSUserDefaults standardUserDefaults];提供唯一的实例 NSUserDefaults存储数据,本质上就是属性列表plist文件里.只不过是系统提供的,存储位置固定的,它存储在沙盒的Li

Android——数据存储(四种方式之二)读写SD卡

Android--数据存储(四种方式) 1.SharedPrefereces 只能保存一些简单的数轻量级.XML  存储文件名, 数据保存在data/data/basepackage/shared_prefs/myopt.xml中    实例-收藏-记住密码自动登录 //一种轻量级的数据存储方式//通过KEY 存入数据--putxxxx(key,value) 取出数据--getxxxx(key  default) 2.读写SD卡  SD的根目录  适用于数据流读写 实现步骤:加入读写SD卡权限

Android开发之数据存储的四种方式之SharedPreferences

Android项目开发中使用的数据存储方式有:网络存储.sqlite存储.File存储和SharedPreferences存 储,四种存储方式对应的Demo别人是NetworkDemo.SqliteDemo.FileDemo和SharedPreferencesDemo, 根据应用的场景选择其中一种或多种方式,比如在登录界面验证,需要将用户名和密码通过SharedPreferences方式保存,注册信息的时候需要通 过网络将数据存储到后台数据库中.结合一个登录界面的验证,使用SharedPrefe