快速将excel数据保存到Oracle数据库中【转】

时间:2022-04-06 01:43:02

我们在工作中,也许会碰到以下情况,客户或者同事发来需要调查的数据,并不是dmp文件,而是excel文件,此时通常是一张表,少量几条记录.最近我恰好碰到了这种情况,所以做了些调查,不敢藏私,拿出来跟大家分享下. 一般的做法,只能对着excel拼写sql语句.如果列数少还好说,表的列数一多的话,这方法既费时又费力.有什么办法可以快捷地导入数据呢?以下的方案可以供大家参考:

Sql*Loader

操作步骤如下:

  1. 录入excel测试表格,test.xls。
  2. 另存为.csv格式
  3. 创建sql*loader控制文件test.ctl,内容如下:
    Load data
    Infile 'c:\test.csv'
    insert Into table test Fields terminated by ','(column1,column2,column3,column4,column5)    
    需要将数据文件拷贝到对应位置
  4. 到数据库中建立对应的测试表test
    create table test (
    column1 Varchar2(10),
    column2 Varchar2(10),
    column3 Varchar2(10),
    column4 Varchar2(10),
    column5 Varchar2(10)
    )
  5. 执行导入命令
    Sqlldr userid = system/manager control='C:\test.ctl'

    导入成功!

附: Sqlldr的函数关键字说明:
Userid   --oracle用户名 userid = username/password
Control --控制文件名称 control = 'e:\insert.ctl'
Log    --日志文件名称 log = 'e:\insert.log'
Bad    --损坏文件名称
Data   --data file name
Discard  --discard file name
Discardmax --number of discards to allow(默认全部)
Skip    --导入时跳过的记录行数(默认0)
Load    --导入时导入的记录行数(默认全部)
Errors   --允许错误的记录行数(默认50)

ctl文件内容说明:
Load data
Infile 'e:\test.csv'  --数据源文件名称
Append|insert|replace --append在表后追加insert插入空表replace替代原有内容
Into table test      --要导入的数据库表名称
[when id = id_memo]    --过滤条件
Fields terminated by',' --字段分隔符
(id,name,telphone)    --字段名称列表

说明:

这种方法的好处是sql*loader是oracle自带软件,无需安装额外的软件.缺点是操作比较麻烦点,而且如果表列数很多的话,输入字段名称列表会比较麻烦,适合导入大量数据.

PL Sql Developer  方法一

  1. 打开excel给需要拷贝的数据增加一个空的起始列 , 选中所要更新的数据,ctr+c  
  2. 打开PL SQl Developer
    1. 输入select * from tab_name for update,按F8运行
    2. 打开锁,此时记录集处于可以编辑的状态,
    3. 点击选中整行, ctrl+v,commit,大功告成

      快速将excel数据保存到Oracle数据库中【转】

说明:这种方法其实是利用PL/SQL developer 对于记录集可以进行整行和多行复制粘贴的特性,toad似乎没有这样快速的办法;

  • 在excel表格的列新追加空列的原因是在PL/SQL Developer选中整行进行粘贴时,前面会有个列数的列,所以要新增加一列,否则会造成列的错位.
  • 这种方法处理少量数据的时候最合适,快捷方便,但是: excel的列必须与表中的列完全匹配

PL Sql Developer  方法二

使用PL SQL Developerd的text importer,这种方法简单方便,推荐此种方法

快速将excel数据保存到Oracle数据库中【转】

方法很简单:

  1. 点击tools->text importer
  2. 在Data from txtfile 页面选择要导入的文件,在Data to Oracle 界面选择要导入的库和表即可
  3. 此时可以看到导入结果预览,还可以查看生成的sql语句,并且对于列可以智能匹配,妙用多多.当然点击Import 就OK了

说明:

这种方法简单可靠,适合导入大量的数据,我猜测这个工具其实是后台根据excel的列生成了相应的sql语句,取代人工拼写sql语句的过程,呵呵,就算生成的sql语句因为一些原因,不是很正确,也可以手工修改.这样既自动又可以手动加以控制,我比较推荐这种方法.

前提是要安装PL/Sql Developer,呵呵

综述:

我这篇文章主要介绍了两种工具用于将excel导入oracle,如果在客户的服务器上等环境受限的情况,没有PL/Sql Developer的话,使用Sql*Loader是个不错的选择;PL/SQL Developer的两种使用方法可以灵活使用,前者快速方便,后者可控性更好,而且无需字段匹配.

快速将excel数据保存到Oracle数据库中【转】的更多相关文章

  1. 将 node.js 的数据保存到 mongo 数据库中

    Mongo 数据库 安装 首先到 Mongo 的官方网站下载安装程序:http://www.mongodb.org/,我下载的文件名为:mongodb-win32-x86_64-2008plus-2. ...

  2. node 爬虫 --- 将爬取到的数据,保存到 mysql 数据库中

    步骤一:安装必要模块 (1)cheerio模块 ,一个类似jQuery的选择器模块,分析HTML利器. (2)request模块,让http请求变的更加简单 (3)mysql模块,node连接mysq ...

  3. Python scrapy爬虫数据保存到MySQL数据库

    除将爬取到的信息写入文件中之外,程序也可通过修改 Pipeline 文件将数据保存到数据库中.为了使用数据库来保存爬取到的信息,在 MySQL 的 python 数据库中执行如下 SQL 语句来创建 ...

  4. mysql触发器的使用 想让b字段在更新的时候把旧数据保存到a字段中

    使用mysql希望数据库自动触发一些规则,进行更新数据的时候,就需要用触发器了,比如 将旧数据保存到额外字段中,如何做呢? 在abc表中 name更新的时候 我希望把name的老数据保存到 old_n ...

  5. 我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中:

    我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中: C/C++ code   ? 1 int retrieve(int scanno,void* buf); 在 ...

  6. Python实现将图片以二进制格式保存到MySQL数据库中,以及取出:

    创建数据库表格式: CREATE TABLE photo ( photo_no int(6) unsigned NOT NULL auto_increment, image MEDIUMBLOB, P ...

  7. 简单抓取安居客房产数据,并保存到Oracle数据库

    思路和上一篇差不多,先获取网站html文件,使用BeautifulSoup进行解析,将对应属性取出,逐一处理,最后把整理出的记录保存到oracle中,持久化储存. '''Created on 2017 ...

  8. 使用scrapy爬取的数据保存到CSV文件中,不使用命令

    pipelines.py文件中 import codecs import csv # 保存到CSV文件中 class CsvPipeline(object): def __init__(self): ...

  9. [转] JAVA读取excel数据(插入oracle数据库)

    原文地址:http://blog.csdn.net/zczzsq/article/details/16803349 本实例做的是读取execl(只能读取.xls的execl,即只能读取03版的),如果 ...

随机推荐

  1. JavaScript权威设计--JavaScript数组(简要学习笔记九)

    1.数组的创建 如: var a=[1.1,null,"a"]; var b=[1, ,3]; //中间的那个元素是undefined var c=[ , , ] 这里c.leng ...

  2. GJM : Unity调用系统窗口选择本地文件

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  3. 【CQgame】[下一百层] [Down]

    简单的下一百层的c++实现,代码一晚上就码完了 注意:游戏前请在 默认值 或 属性 中调整缓冲区大小,否则会输出爆屏,方法写在代码里了 觉得速度 快/慢 的可以在第 23 行手动改一下,相信大神们能看 ...

  4. 【转】NPOI 单元格级别应用

    NPOI 单元格级别应用A HSSFWorkbook hssfworkbook = new HSSFWorkbook();//初始化一个新的HSSFWorkbook实例 //#region 1.创建一 ...

  5. HDU 5670 Machine

    Machine Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  6. GOF23种设计模式精解

    创建型 1. Factory Method(工厂方法) 2. Abstract Factory(抽象工厂) 3. Builder(建造者) 4. Prototype(原型) 5. Singleton( ...

  7. Greenplum hostname和address不一致导致配置文件无法加载

    最近又遇到了几个坑,逐一记录分析下. 1.主机名hostname和address不一致 在又一次部署压测环境交由测试组进行压测时,同事修改了pg_hba.conf文件重新加载配置文件时报错.(找不到l ...

  8. redis客户端、分布式锁及数据一致性

    Redis Java客户端有很多的开源产品比如Redission.Jedis.lettuce等. Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持:Redis ...

  9. Deep Learning.ai学习笔记_第三门课_结构化机器学习项目

    目录 第一周 机器学习策略(1) 第二周 机器学习策略(2) 目标:学习一些机器学习优化改进策略,使得搭建的学习模型能够朝着最有希望的方向前进. 第一周 机器学习策略(1) 搭建机器学习系统的挑战:尝 ...

  10. ES6学习笔记<四> default、rest、Multi-line Strings

    default 参数默认值 在实际开发 有时需要给一些参数默认值. 在ES6之前一般都这么处理参数默认值 function add(val_1,val_2){ val_1 = val_1 || 10; ...