ORACLE导入大量数据的两种方式比较
不管是开发还是测试,工作中经常需要去批量新增测试数据,但是大量数据的新增速度有时候让我们苦不堪言,下面通过两种方式完成oracle数据的批量新增,比较两种方式的效率。
第一种方式:采用工具导入sql文件
以10w条数据为例,通过java程序生成insert语句,采用sqlplus进行导入
1、通过简单的JAVA程序生成sql脚本
public class GenerateSQLFile {
public static void main(String[] args) throws Exception {
File file = new File("d:" + File.separator + "data.sql");
OutputStream out = new FileOutputStream(file, true);
for (int i = 1; i <= 100000; i++) {
String str = "insert into t_test(id,name) values(" + i
+ ",'hello world" + i + "');\r\n";
byte b[] = str.getBytes();
out.write(b);
}
out.close();
}
}
执行程序,生成的sql脚本如下所示:
insert into t_test_1(id,name) values(1,'hello world1');
insert into t_test_1(id,name) values(2,'hello world2');
insert into t_test_1(id,name) values(3,'hello world3');
... ...
2、新建表,导入数据
以scott/tiger登录sqlplus;
新建t_test表:create tablet_test_1(id int,name varchar2(255));
创建表成功后执行:@D:\data.sql,逐行插入数据
3、测试结果
以sqlplus执行sql脚本导入10W条数据的时间大约是5分钟
第二种方式:采用sql loader工具
sql loader可以将文本格式存放的数据导入到oracle,是一个进行数据迁移的非常方便而且通用的工具。
下面通过java程序生成csv文件,以100万条测试数据为例,通过sql loader进行数据导入
期望生成的csv数据文件格式如下:
1,hello1
2,hello2
3,hello3
... ...
1、生成数据文件
100万条数据的csv文件同样由java程序生成:
File file = new File("d:" + File.separator + "data.csv"); // 要操作的文件
OutputStream out = null; // 声明字节输出流
out = new FileOutputStream(file, true);
for (int i = 1; i <= 100000; i++) {
String str = i+","+"hello"+i+"\r\n";
byte b[] = str.getBytes();
out.write(b);
}
out.close();
2、创建表格t_test_2
create table t_test_2(id varchar2(255),name varchar2(255));
3、建立控制文件test.ctl,脚本如下
load data
infile data.csv
into table t_test_2
(
id char terminated by ',',
name char terminated by whitespace
)
参数说明:
Infile data.csv: 指定数据源文件 这里我们省略了默认的 discardfile result.dsc badfile result.bad
into table t_test_2:默认是INSERT,也可以into table resultxt APPEND为追加方式,或REPLACE
terminated by ',':指用逗号进行字段的分隔
terminated by whitespace: 表示结尾以空白分隔
其它参数参考可使用命令:d:\>sqlldr
4、导入数据:
将test.ctl文件和data.csv文件放置在D盘根目录下,在命令行中运行:
D:\>sqlldr userid=scott/tiger control=test.ctl
5、测试结果:通过sql loader进行数据导入,10万条数据毫秒级导入,100万条数据耗时10秒
ORACLE导入大量数据的两种方式比较的更多相关文章
- 【代码笔记】iOS-向服务器传JSON数据的两种方式
一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. ...
- angular学习笔记(三)-视图绑定数据的两种方式
绑定数据有两种方式: <!DOCTYPE html> <html ng-app> <head> <title>2.2显示文本</title> ...
- C++读取字符串数据的两种方式
C++读取字符串数据的两种方式 对于同样的样例输入: ladder came tape soon leader acme RIDE lone Dreis peat ScAlE orb eye Ride ...
- easyUI之datagrid绑定后端返回数据的两种方式
先来看一下某一位大佬留下的easyUI的API对datagrid绑定数据的两种方式的介绍. 虽然精简,但是,很具有“师傅领进门,修行靠个人”的精神,先发自内心的赞一个. 但是,很多人和小编一样,第一次 ...
- SparkStreaming获取kafka数据的两种方式:Receiver与Direct
简介: Spark-Streaming获取kafka数据的两种方式-Receiver与Direct的方式,可以简单理解成: Receiver方式是通过zookeeper来连接kafka队列, Dire ...
- SparkStreaming与Kafka,SparkStreaming接收Kafka数据的两种方式
SparkStreaming接收Kafka数据的两种方式 SparkStreaming接收数据原理 一.SparkStreaming + Kafka Receiver模式 二.SparkStreami ...
- oracle删除表数据的两种的方式
转自:https://blog.csdn.net/qq_37840993/article/details/82490787 平时写sql中我们都会用到删除语句,而平时删除表数据的时候我们经常会用到两种 ...
- oracle 插入表数据的4种方式
1.往表中插入一整行数据 /*方法一*/ INSERT INTO 表名 VALUES(val1,val2,val3,...); /*方法二*/ '; 如: ,, FROM DUAL; 注意: 2. ...
- Java解析Json数据的两种方式
JSON数据解析的有点在于他的体积小,在网络上传输的时候可以更省流量,所以使用越来越广泛,下面介绍使用JsonObject和JsonArray的两种方式解析Json数据. 使用以上两种方式解析json ...
随机推荐
- Python实现随机漫步
随机漫步生成是无规则的,是系统自行选择的结果.根据设定的规则自定生成,上下左右的方位,每次所经过的方向路径. 首先,创建一个RandomWalk()类和fill_walk()函数 random_wal ...
- RabbitMQ配置
RabbitMQ Configuration RabbitMQ提供多种配置方式:配置文件.环境变量.运行时参数等等. 默认配置文件的位置在/etc/rabbitmq/ Config File Loca ...
- Android--UI之ViewStub
前言 按照最近博客的路线,继续讲Android的UI开发.今天讲解一下ViewStub控件,惰性装载控件.在本篇博客中,将了解到ViewStub的常用属性.方法,以及注意事项.最后将以一个简单的Dem ...
- CountDownLatch/CyclicBarrie用法记录
在jdk1.5中,java提供了很多工具类帮助我们进行并发编程,其中就有CountDownLatch和CyclicBarrie 1.CountDownLatch的用法 CountDownLatch 位 ...
- ZOJ Problem Set - 1730 Crazy Tea Party
#include<cstdio> int main(){ int T,n; scanf("%d",&T); while(T--){ scanf("%d ...
- 简单快速的让你的json解析速度快上加快
背景 最近小编在做公司的一个需求.要求是把系统内的一些大型文本文件上传到第三方那里,而且第三方要求的交互数据的方式是采用post请求发送json串的形式进行的. 问题 做到中途才发现问题,由于单个文本 ...
- Docker 设置固定网络IP
1.创建自定义网络: 2.查看自定义网络: 3.启动容器: 4.查看容器IP:
- Elastic Search 安装和配置
目标 部署一个单节点的ElasticSearch集群 依赖 java环境 $java -version java version "1.8.0_161" Java(TM) SE R ...
- 跟面试官聊.NET垃圾收集,直刺面试官G点
装逼的面试官和装逼的程序员 我面试别人的时候,经常是按这种路子来面试: 看简历和面试题,从简历和面试题上找到一些技术点,然后跟应聘者聊. 聊某个技术点的时候,应聘者的回答会牵涉到其他的技术点,然后我会 ...
- #2 Python面向对象(一)
前言 对于萌新来说,面向对象,这是一个很陌生的词语.如果你接触过Linux,你一定知道“一切皆文件”,也就是说,在Linux中所有都是文件,鼠标是文件.键盘是文件.目录是文件等等一切都是文件:Pyth ...