7. Oracle數據加載和卸載

  在日常工作中;經常會遇到這樣的需求:

    • Oracle 數據表跟文本或者文件格式進行交互;即將指定文件內容導入對應的 Oracle 數據表中;或者從 Oracle 數據表導出。
    • 其他數據庫中的表跟Oracle數據庫進行交互。

  若是少量數據;可選擇的解決方案有很多。常用的用 Pl/SQL developer工具,或者手動轉換為 INSERT 語句,或者通過API。但數據量大;用上面的方法效率太爛了。本文來說說 Oracle 數據的加載和卸載。

    • Oracle中的DBLINK
    • Oracle加載數據-外部表
    • Oracle加載數據-sqlldr工具
    • Oracle卸載數據-sqludr

一. Oracle 中的 DBLINK

  在日常工作中;會遇到不同的數據庫進行數據對接;每個數據庫都有著功能;像Oracle有 DBLINK ; PostgreSQL有外部表。

1.1 Oracle DBlink 語法

CREATE [PUBLIC] DATABASE LINK link 
CONNECT TO username 
IDENTIFIED BY password
USING 'connectstring'

1.2 Oracle To Mysql

  在oracle配置mysql數據庫的dblink

二.Oracle加載數據-外部表

  ORACLE外部表用來存取數據庫以外的文本文件(Text File)或ORACLE專屬格式文件。因此,建立外部表時不會產生段、區、數據塊等存儲結構,只有與表相關的定義放在數據字典中。外部表,顧名思義,存儲在數據庫外面的表。當存取時才能從ORACLE專屬格式文件中取得數據,外部表僅供查詢,不能對外部表的內容進行修改(INSERT、UPDATE、DELETE操作)。不能對外部表建立索引。

2.1 創建外部表需要的目錄

# 創建外部表需要的目錄
SQL> create or replace directory DUMP_DIR as '/data/ora_ext_lottu'; Directory created.
# 給用戶授予指定目錄的操作權限
SQL> GRANT READ,WRITE ON DIRECTORY DUMP_DIR TO lottu;Grant succeeded.

2.2 外部表源文件lottu.txt

10,ACCOUNTING,NEW YORK
20,RESEARCH,DALLAS
30,SALES,CHICAGO
40,OPERATIONS,BOSTON

2.3 創建外部表

drop table dept_external purge;CREATE TABLE dept_external (deptno     NUMBER(6),dname      VARCHAR2(20),loc        VARCHAR2(25) 
)
ORGANIZATION EXTERNAL
(TYPE oracle_loaderDEFAULT DIRECTORY DUMP_DIRACCESS PARAMETERS(RECORDS DELIMITED BY newlineBADFILE 'lottu.bad'LOGFILE 'lottu.log'FIELDS TERMINATED BY ","  OPTIONALLY ENCLOSED BY '"'(deptno     INTEGER EXTERNAL(6),dname      CHAR(20),loc        CHAR(25)))LOCATION ('lottu.txt')
)
REJECT LIMIT UNLIMITED;

查看數據

SQL> select * from dept_external;DEPTNO DNAME  LOC
---------- -------------------- -------------------------10 ACCOUNTING  NEW YORK20 RESEARCH  DALLAS30 SALES  CHICAGO40 OPERATIONS  BOSTON

三. Oracle加載數據-sqlldr工具

3.1 準備實驗對象

  創建文件lottu.txt;和表tbl_load_01。

[oracle@oracle235 ~]$ seq 1000|awk -vOFS="," '{print $1,"lottu",systime()-$1}' > lottu.txt
[oracle@oracle235 ~]$ sqlplus lottu/li0924SQL*Plus: Release 11.2.0.4.0 Production on Mon Aug 13 22:58:34 2018Copyright (c) 1982, 2013, Oracle.  All rights reserved.Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing optionsSQL> create table tbl_load_01 (id number,name varchar2(10),accountid number);Table created.

3.2 創建控制文件lottu.ctl

load data
characterset utf8infile '/home/oracle/lottu.txt'truncate into table tbl_load_01fields terminated by ','trailing nullcolsoptionally enclosed by ' ' TRAILING NULLCOLS
(id ,name,accountid
)

3.3 執行sqlldr

[oracle@oracle235 ~]$ sqlldr 'lottu/"li0924"' control=/home/oracle/lottu.ctl log=/home/oracle/lottu.log bad=/home/oracle/lottu.badSQL*Loader: Release 11.2.0.4.0 - Production on Mon Aug 13 23:10:12 2018Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.Commit point reached - logical record count 64
Commit point reached - logical record count 128
Commit point reached - logical record count 192
Commit point reached - logical record count 256
Commit point reached - logical record count 320
Commit point reached - logical record count 384
Commit point reached - logical record count 448
Commit point reached - logical record count 512
Commit point reached - logical record count 576
Commit point reached - logical record count 640
Commit point reached - logical record count 704
Commit point reached - logical record count 768
Commit point reached - logical record count 832
Commit point reached - logical record count 896
Commit point reached - logical record count 960
Commit point reached - logical record count 1000

四.Oracle卸載數據-sqludr

  sqludr是將Oracle數據表導出到文本中;是牛人樓方鑫開發的。并非Oracle自帶工具;需要下載安裝才能使用。

4.1 sqludr安裝

[oracle@oracle235 ~]$ unzip sqluldr2linux64.zip 
Archive:  sqluldr2linux64.zipinflating: sqluldr2linux64.bin     
[oracle@oracle235 ~]$ mv sqluldr2linux64.bin $ORACLE_HOME/bin/sqludr

4.2 查看sqludr幫助

[oracle@oracle235 ~]$ sqludr -?SQL*UnLoader: Fast Oracle Text Unloader (GZIP, Parallel), Release 4.0.1
(@) Copyright Lou Fangxin (AnySQL.net) 2004 - 2010, all rights reserved.License: Free for non-commercial useage, else 100 USD per server.Usage: SQLULDR2 keyword=value [,keyword=value,...]Valid Keywords:user    = username/password@tnsnamesql     = SQL file namequery   = select statementfield   = separator string between fieldsrecord  = separator string between recordsrows    = print progress for every given rows (default, 1000000) file    = output file name(default: uldrdata.txt)log     = log file name, prefix with + to append modefast    = auto tuning the session level parameters(YES)text    = output type (MYSQL, CSV, MYSQLINS, ORACLEINS, FORM, SEARCH).charset = character set name of the target database.ncharset= national character set name of the target database.parfile = read command option from parameter file for field and record, you can use '0x' to specify hex character code,\r=0x0d \n=0x0a |=0x7c ,=0x2c, \t=0x09, :=0x3a, #=0x23, "=0x22 '=0x27 

4.3 執行sqludr

[oracle@oracle235 ~]$ sqludr lottu/li0924 query="tbl_load_01" file=lottu01.txt field=","0 rows exported at 2018-08-13 23:47:55, size 0 MB.1000 rows exported at 2018-08-13 23:47:55, size 0 MB.output file lottu01.txt closed at 1000 rows, size 0 MB.

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450839.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450839.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450839.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Navicat工具導出mySQL數據庫某個視圖結構的.sql腳本

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 用Navicat工具怎么都導不出來mySQL數據庫的某個視圖.sql腳本,即使導出來也只是包含視圖記錄,不包含視圖結構。經…

瞧瞧蘋果OS X如何干掉Linux

摘要:如果你去過Facebook或者其它一些創業類科技公司,你會發現隨處可見的Mac,無論是CEO還是開發者,都可能在使用Mac。而以往很受IT人士青睞的Linux好像在消失,這是真的嗎?蘋果OS X是如何干掉Linux的&#x…

超全十大經典排序算法及其分析

文章目錄0.算法概述0.1 算法分類0.2 算法復雜度0.3 相關概念1. 冒泡排序(Bubble Sort)1.1 算法描述:1.2 圖解演示1.3 代碼實現1.4 優化過程1.5 性能分析2. 選擇排序(Selection Sort)2.1 算法描述:2.2 圖解演…

eclipse安裝JAVA反編譯插件

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 前言:在實際的開發中幾乎都會使用到一些框架來輔助項目的開發工作,對于一些框架的代碼我們總懷有一些好奇之心&a…

noip2014生活大爆炸版石頭剪刀布

題目描述 石頭剪刀布是常見的猜拳游戲:石頭勝剪刀,剪刀勝布,布勝石頭。如果兩個人出拳一 樣,則不分勝負。在《生活大爆炸》第二季第8集中出現了一種石頭剪刀布的升級版游戲。 升級版游戲在傳統的石頭剪刀布游戲的基礎上,增加了兩個新手勢: 斯波克:《星際迷航》主角之…

初識react(二) 實現一個簡版的html+redux.js的demo

回顧 初識react(一) 揭開jsx語法和虛擬DOM面紗初識react(二) 實現一個簡版的htmlredux.js的demo初識react(三)在 react中使用redux來實現簡版計數器初識react(四) react中異步解決方案之 redux-saga初識react(五) 數據流終極解決方案 dva(零配置)前言 首先糾正個誤區&#xff0…

12個有趣的C語言面試題

摘要&#xff1a;12個C語言面試題&#xff0c;涉及指針、進程、運算、結構體、函數、內存&#xff0c;看看你能做出幾個&#xff01; 1.gets()函數 問&#xff1a;請找出下面代碼里的問題&#xff1a; #include<stdio.h> int main(void) { char buff[10]; memset…

超全Typora快速入門

文章目錄一.Typora快速入門1.代碼塊2.標題3.字體4.引用5.水平分割線6.圖片插入7.超鏈接8.列表9.表格10.任務列表11.數學表達式12.生成目錄13.表情符號14.定義腳注15.文件導出16.主題修改17.修改主題背景圖片18.設置背景透明度19.Typora 插入圖片調整大小20.字體和顏色21.頁內跳…

聊聊畢業設計系列 --- 系統實現

效果展示 github moment-server github地址 moment github地址 moment-manage github地址 articles 聊聊畢業設計系列 --- 項目介紹 聊聊畢業設計系列 --- 系統實現 前言 在上一篇文章中&#xff0c;主要是對項目做了介紹&#xff0c;并且對系統分析和系統設計做了大概的介紹。…

求職小記(持續更新)

自16年春正式工作以來也有兩年半了&#xff0c;也許是對現在leader的不滿。也許是想要折騰一下&#xff0c;也許還有也許&#xff0c;決定換一份工作&#xff0c;結束兩年零四個月的第一家it工作。從8月份的離職到十月底的offer經歷了很多&#xff0c;外面天慢慢的涼了&#xf…

js 實現用window.print()打印頁面中的部分內容,局部打印

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 如下方法&#xff1a; function printProof(){var printData document.getElementById("forPrint").innerHTML; // 只打印 f…

搞懂靜態變量static

文章目錄1.什么是static&#xff1f;2.static關鍵字的作用是什么&#xff1f;3.靜態變量和非靜態變量的區別&#xff1f;4.static可以修飾局部變量嗎&#xff1f;5.可以通過this訪問靜態變量嗎&#xff1f;6.靜態方法能否調用非靜態方法&#xff1f;7.靜態變量、普通變量、靜態…

神經網絡優化(二) - 滑動平均

1 滑動平均概述 滑動平均&#xff08;也稱為 影子值 &#xff09;&#xff1a;記錄了每一個參數一段時間內過往值的平均&#xff0c;增加了模型的泛化性。 滑動平均通常針對所有參數進行優化&#xff1a;W 和 b&#xff0c; 簡單地理解&#xff0c;滑動平均像是給參數加了一個影…

Docker完全自學手冊

阿里云大學免費課程&#xff1a;Docker完全自學手冊課程介紹&#xff1a;Docker 是 PaaS 提供商 dotCloud 開源的一個基于 LXC 的高級容器引擎&#xff0c;源代碼托管在 Github 上, 基于go語言并遵從Apache2.0協議開源。Docker 是一個開源的應用容器引擎&#xff0c;讓開發者可…

Spring 之注解事務 @Transactional

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 先讓我們看代碼吧&#xff01; 以下代碼為在“Spring3事務管理——基于tx/aop命名空間的配置”基礎上修改。首先修改applicationContext…

超級程序員神話

摘要&#xff1a;大部分的程序員在思想里都會某種程度的承認&#xff0c;承認自己只是一個普通的程序員&#xff0c;但這世界上確實有一些超級程序員&#xff0c;在一個為企業開發應用的程序員和一個為谷歌寫搜索算法的程序員之間&#xff0c;或和一個開發用來控制讀寫頭從磁盤…

HashMap30連問,徹底搞懂HashMap

文章目錄一、背景知識1、什么是Map&#xff1f;2、什么是Hash&#xff1f;3、什么是哈希表&#xff1f;4、什么是HashMap?5、如何使用HashMap&#xff1f;6、HashMap有哪些核心參數&#xff1f;7、HashMap與HashTable的對比&#xff1f;8、HashMap和HashSet的區別&#xff1f;…

博弈論的算法總結

開頭先啰嗦一句&#xff1a;想學好博弈&#xff0c;必然要花費很多的時間&#xff0c;深入學習&#xff0c;不要存在一知半解&#xff0c;應該是一看到題目&#xff0c;就想到博弈的類型。 以及&#xff0c;想不斷重復不斷重復&#xff0c;做大量各大oj網站的題目&#xff0c;最…

Slog55_lua面向對象之lua類

Slog55_lua面向對象之lua類 ArthurSlog SLog-55 Year1 GuangzhouChina Aug 30th 2018 微信掃描二維碼&#xff0c;關注我的公眾號GitHub 掘金主頁 簡書主頁 segmentfault 現實中的事情不是根據人的喜好而定的 比如長在你嘴里的智齒 大部分情況下 你會因為自己&#xff0…

Spring中的@scope注解

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Scope 簡單點說就是用來指定bean的作用域作用域 &#xff08;官方解釋&#xff1a;scope用來聲明IOC容器中的對象應該處的限定場景或者…