Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx

上传人:b****8 文档编号:9892361 上传时间:2023-02-07 格式:DOCX 页数:14 大小:21.74KB
下载 相关 举报
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx_第1页
第1页 / 共14页
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx_第2页
第2页 / 共14页
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx_第3页
第3页 / 共14页
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx_第4页
第4页 / 共14页
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx

《Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx》由会员分享,可在线阅读,更多相关《Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx(14页珍藏版)》请在冰豆网上搜索。

Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx

Ubuntu环境利用ORALCE数据泵批量导出数据库表

Ubuntu环境利用ORALCE数据泵批量导出数据库表

目录

1.简介2

2.VM安装2

3.Ubuntu安装2

4.Ubuntu使用2

4.1.权限问题及登入界面2

4.2.乱码显示问题2

4.3.访问共享3

4.4.WIN8下访问Ubuntu3

5.Ubuntu下ORACLE的安装4

5.1.将系统更新到最新4

5.2.安装桌面程序4

5.3.安装Oracle所需的依赖包4

5.4.创建ORACLE用户5

5.5.检查系统变量5

5.6.添加对oracle用户的内核限制6

5.7.ORACLE文件夹创建6

5.8.JDK安装7

5.9.设置Oracle配置环境变量8

5.10.软链接8

5.11.Oracle安装9

5.12.安装过程可能会出现一些错误10

5.13.安装成功11

6.SHELL编程11

6.1.批量导出ORALCE表11

1.简介

本文档简要介绍Ubuntu14安装及使用(在虚拟机环境VM),Ubuntu与宿主机(WIN8.1)的网络共享及上网,在Ubuntu14下安装ORACLE11GR2,以及利用VI编写SHELL脚本实现ORACLE数据泵方式批量导入导出数据。

2.VM安装

VM的使用安装比较简单,不会出现什么问题,我用的VM的版本是VMware-workstation-full-10.0.2

3.Ubuntu安装

Ubuntu的版本最好选择较近的,刚开始我安装了Ubuntu9,在使用过程中发现很多工具都比较久,需要用到的工具都要进行更新,后面就选择了Ubuntu14.Ubuntu14可以从下面地址下载(

4.Ubuntu使用

4.1.权限问题及登入界面

安装完Ubuntu默认登入的是窗体界面。

窗体界面输入快捷键SHIFT+ALT+F2进入命令行界面,在命令行界面输入SHIFT+ALT+F7进入窗体界面.在窗体界面也可以使用命令行方式,按ALT+F2,在出现的运行对话框中输入GNOME-TERMINAL回车。

安装完Ubuntu默认使用的账户是安装时新建的账户,这个账户是受限的。

因此在安装或者使用一些其它命令时需要使用到管理员权限,有如下几种方式:

SUDO+命令(例:

SUDOMKDIR/USR/LIZQ1),使用管理员账号ROOT,初次使用需要设置密码(用命令PASSWDROOT就可以设置密码)。

4.2.乱码显示问题

解决方法1:

修改/etc/default/locale

sudovim/etc/default/locale1

修改默认的

LANG=zh_CN.UTF-8

LANGUAGE=zh_CN:

zh

为:

LANG="en_US.UTF-8"

LANGUAGE="en_US:

en"

存盘退出

然后:

sudoreboot

再然后

env或者locale查看修改后的结果就可以了...

解决方法2:

这才是我想说的...安装个zhcon就可以了...

终端或者命令行里输入

sudoapt-getinstallzhcon

等安装完即可~

运行的时候记得要加载vgz驱动和utf8支持否则会黑屏...

并且只能在纯命令行里运行在终端运行会出错

所以你的命令应该是zhcon--utf8--drv=vga

如果嫌每次都要输入这么多太麻烦可以在~/.bashrc里面加一个别名

sudovim~/.bashrc

打开后在里面加入一行

aliaszhcon='zhcon--utf8--drv=vga'

保存退出

这样每次进入命令行后直接运行zhcon即可不用担心黑屏问题

zhcon中支持中文显示也支持中文输入法由于热键冲突问题暂时我只知道Ctrl+space切换到全拼输入法是

可以用的多多少少解决了点中文目录/文件名的问题了

4.3.ubuntu中shell脚本无法使用source

现象:

shell脚本中sourceaaa.sh时提示source:

notfound

原因:

ls-l`whichsh`提示/bin/sh->dash

这说明是用dash来进行解析的。

改回方法:

命令行执行:

sudodpkg-reconfiguredash

在界面中选择no

再ls-l`whichsh`提示/bin/sh->bash

修改成功,source可以用了~

4.4.访问共享

运行Smbclient\\IP地址\共享文件夹-Uuser,进入共享目录,使用GET获取共享文件,使用PUT存放文件到共享

4.5.WIN8下访问Ubuntu

在WIN8安装SecureCRT7,在Ubuntu下安装SSHSERVER(sudoapt-getinstallopenssh-server),检测SSH-server安装情况(ps-e|grepssh)。

5.Ubuntu下ORACLE的安装

我这是在Ubuntu1432位下安装32位ORALCE11GR2.安装过程还是非常复杂的。

下面是参考网上的安装方法

5.1.将系统更新到最新

sudoapt-getupdate

sudoapt-getdist-upgrade

5.2.安装桌面程序

如果使用的Ubuntu不是桌面版(如Ubuntuserver),由于Oracle安装需要用到图形界面,所以需要安装桌面程序:

sudoapt-getinstallgnome-core

相信很多都是使用的桌面版,那么这个步骤就不需要了。

5.3.安装Oracle所需的依赖包

sudoapt-getinstallautomake

sudoapt-getinstallautotools-dev

sudoapt-getinstallbinutils

sudoapt-getinstallbzip2

sudoapt-getinstallelfutils

sudoapt-getinstallexpat

sudoapt-getinstallgawk

sudoapt-getinstallgcc

sudoapt-getinstallgcc-multilib

sudoapt-getinstallg++-multilib

sudoapt-getinstallia32-libs

sudoapt-getinstallksh

sudoapt-getinstallless

sudoapt-getinstalllesstif2

sudoapt-getinstalllesstif2-dev

sudoapt-getinstalllib32z1

sudoapt-getinstalllibaio1

sudoapt-getinstalllibaio-dev

sudoapt-getinstalllibc6-dev

sudoapt-getinstalllibc6-dev-i386

sudoapt-getinstalllibc6-i386

sudoapt-getinstalllibelf-dev

sudoapt-getinstalllibltdl-dev

sudoapt-getinstalllibmotif4

sudoapt-getinstalllibodbcinstq4-1libodbcinstq4-1:

i386

sudoapt-getinstalllibpth-dev

sudoapt-getinstalllibpthread-stubs0

sudoapt-getinstalllibpthread-stubs0-dev

sudoapt-getinstalllibstdc++5

sudoapt-getinstalllsb-cxx

sudoapt-getinstallmake

sudoapt-getinstallopenssh-server

sudoapt-getinstallpdksh

sudoapt-getinstallrlwrap

sudoapt-getinstallrpm

sudoapt-getinstallsysstat

sudoapt-getinstallunixodbc

sudoapt-getinstallunixodbc-dev

sudoapt-getinstallunzip

sudoapt-getinstallx11-utils

sudoapt-getinstallzlibc

很多都是Ubuntu自带的了,谨慎6起见都执行一遍吧。

5.4.创建ORACLE用户

(此步可省略,直接使用当前的用户即可,下面的安装过程都是以不执行这一步为准的)

sudogroupaddoinstall

sudogroupadddba

sudouseradd-goinstall-Gdba-d/opt/oracle-s/bin/bashoracle

sudopasswdoracle

5.5.检查系统变量

/sbin/sysctl-a|grepsem

/sbin/sysctl-a|grepshm

/sbin/sysctl-a|grepfile-max

/sbin/sysctl-a|grepaio-max

/sbin/sysctl-a|grepip_local_port_range

/sbin/sysctl-a|greprmem_default

/sbin/sysctl-a|greprmem_max

/sbin/sysctl-a|grepwmem_default

/sbin/sysctl-a|grepwmem_max

 

然后根据上面命令中得到的参数值在/etc/sysctl.conf中增加对应数据,比如:

fs.aio-max-nr=1048576

fs.file-max=6815744

kernel.shmall=2097152kernel.shmmax=536870912

kernel.shmmni=4096kernel.sem=25032000100128

net.ipv4.ip_local_port_range=900065500

net.core.rmem_default=262144

net.core.rmem_max=4194304

net.core.wmem_default=262144

net.core.wmem_max=1048586

运行一下命令更新内核参数:

sysctl–p

5.6.添加对oracle用户的内核限制

添加对oracle用户的内核限制在/etc/security/limits.conf文件中增加以下数据

oraclesoftnproc2047

oraclehardnproc16384

oraclesoftnofile1024

oraclehardnofile65536

oraclesoftstack10240

其中oracle是在第四步中创建的用户,跳过第四步的话就写当前用户

查看/etc/pam.d/login,增加以下行(有了就不用增加了):

sessionrequiredpam_limits.so

同样检查/etc/pam.d/su,没有以下行就自己加上:

sessionrequiredpam_limits.so

5.7.ORACLE文件夹创建

创建需要的文件夹(用于安装oracle)并设置其所有权:

mkdir-p/opt/oracle

mkdir-p/opt/oraInventory

chown-Roracle:

oinstall/opt/oracle

chown-Roracle:

oinstall/opt/oraInventory

同样,如果跳过了第四步,那就将所有权设置命令中的用户oracle和组oinstall改为自己当前用户和组(通常二者是一样的),当然这时也可以不执行这两个chown命令,本来目录创建者就是所有者了。

另外,需要root权限执行这些命令(sudo,下同)

5.8.JDK安装

如果Ubuntu上没安装JRE的话,需要安装JRE(我这里直接安装了JDK,以JDK为例):

到Oracle官网下载JDK6(最新为7,考虑到兼容性问题,安装6):

下载jdk-6u45-linux-i586.bin这个文件。

放到主文件夹(home目录)下,进入终端:

$sudochmod777jdk-6u37-linux-x64.bin//将文件赋予运行权限

$sudo-s./jdk-6u37-linux-x64.bin/usr/lib/jdk//将JDK安装到/usr/lib/jdk目录下。

注意:

最后安装完成后可能安装到了主文件夹下了,这是使用命令将其全部复制到/usr/lib/jdk目录下即可。

(如果没有权限,就使用sudochmod777获取权限再复制)

配置JDK的环境变量,使用编辑器打开主文件夹下的.bashrc配置文件(隐藏),向其中加入如下内容:

#JDK

JAVA_HOME=/usr/lib/jdk/jdk1.6.0_45

JRE_HOME=${JAVA_HOME}/jre

exportANDROID_JAVA_HOME=$JAVA_HOME

exportCLASSPATH=.:

${JAVA_HOME}/lib:

$JRE_HOME/lib:

$CLASSPATH

exportJAVA_PATH=${JAVA_HOME}/bin:

${JRE_HOME}/bin

exportJAVA_HOME;

exportJRE_HOME;

exportCLASSPATH;

HOME_BIN=~/bin/

exportPATH=${PATH}:

${JAVA_PATH}:

${HOME_BIN};

注意核对一下目录结构是不是正确的。

最后验证JDK是否安装正确:

java-version

出现了JDK版本信息就表示正确了。

5.9.设置Oracle配置环境变量

同样在主文件夹下的.bashrc配置文件中加入如下内容:

#Oracle

#这个写刚刚创建的文件夹

exportORACLE_BASE=/opt/oracle

#这个后面可以随便填写

exportORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1

#数据库的sid

exportORACLE_SID=orcl

exportORACLE_UNQNAME=orcl

#默认字符集

exportNLS_LANG=.AL32UTF8

#环境变量

exportPATH=${PATH}:

${ORACLE_HOME}/bin/;

5.10.软链接

oracle本身并不支持ubuntu来安装,所以要进行欺骗oracle的安装程序(sudo执行):

ln-s/etc/etc/rc.d

ln-s/lib/i386-linux-gnu/libgcc_s.so.1/lib/

ln-s/usr/bin/awk/bin/awk

ln-s/usr/bin/basename/bin/basename

ln-s/usr/bin/rpm/bin/rpm

ln-s/usr/lib/i386-linux-gnu/libpthread_nonshared.a/usr/lib/libpthread_nonshared.a

ln-s/usr/lib/i386-linux-gnu/libc_nonshared.a/usr/lib/libc_nonshared.a

ln-s/usr/lib/i386-linux-gnu/libstdc++.so.6/lib/

ln-s/usr/lib/i386-linux-gnu/libstdc++.so.6/usr/lib/

ln-s/usr/lib/i386-linux-gnu/libstdc++.so.5/lib/

ln-s/usr/lib/i386-linux-gnu/libstdc++.so.5/usr/lib/

echo‘RedHatLinuxrelease5’>/etc/redhat-release

注意:

以上命令是对应于32位Ubuntu安装32位Oracle的,如果是64位Ubuntu安装64位Oracle,上面的i386-linux-gnu就都要改成x86_64-linux-gnu,目标目录的lib也要改成lib64.(没有lib64就新建一个)

因为Ubuntu将某些库文件根据32位系统和64位系统分别存放了,但Oracle只认/usr/lib和/lib目录,所以需要进行上面的软链接。

5.11.Oracle安装

下载Linuxx86的那两个文件(64位系统就下Linuxx86-64),解压后得到database文件夹。

正式安装Oracle,为database文件夹下的runInstaller文件赋予可执行权限:

chmod777runInstaller

跳转到database目录,在终端下执行:

./runInstaller

此时可能会出现database目录下部分文件的权限不足,导致安装程序无法启动的问题,根据提示,对那些文件使用chmod777进行授权就行了(貌似一共3个文件)。

启动安装图形界面后,可能会发现文字乱码,全是口口口:

 

这时可以关闭该界面,先在终端输入:

exportLANG=en_US

或者

exportLANG=zh_CN.gbk

然后再执行:

./runInstaller

就可以在全英文界面下进行安装了。

5.12.安装过程可能会出现一些错误

图形界面下进行依赖检查的时候会列出很多依赖检查失败了,无法进入下一步了,此时选中右上角的‘忽略所有’就可以进入下一步了。

如果没有严格按照前面的要求做,安装过程中可能弹出错误,此时不要关闭界面,根据给出的日志位置,在日志中查看错误出现的原因,一般都是指定位置找不到相应的文件导致的,此时打开一个新的终端窗口,找到这些文件并将文件复制到对应的位置或者创建软链接即可。

(通常是/usr/lib目录下找不到库文件,这些库文件都位于/usr/lib/i386-linux-gnu目录下了)然后在图形界面点击“Retry‘即可继续安装。

比如“errorininvokingtarget'client_sharedlib'ofmakefile'/opt/oracle11g/server/rdbms/lib/ins_rdbms.mk''这个错误就是没有执行:

ln-s/usr/lib/i386-linux-gnu/libpthread_nonshared.a/usr/lib/libpthread_nonshared.a

ln-s/usr/lib/i386-linux-gnu/libc_nonshared.a/usr/lib/libc_nonshared.a

这两个命令导致的(针对32位安装的情况)。

 

即使严格按照要求做了,还是会出现两个错误:

a.解决办法:

打开一个新的终端,输入如下命令:

sed-i's/^\(\s*\$(MK_EMAGENT_NMECTL)\)\s*$/\1-lnnz11/g'$ORACLE_HOME/sysman/lib/ins_emagent.mk

然后在图形界面点击‘Retry’就能继续安装了。

b.解决办法:

打开一个新的终端,输入如下四个命令:

sed-i's/^\(TNSLSNR_LINKLINE.*\$(TNSLSNR_OFILES)\)\(\$(LINKTTLIBS)\)/\1-Wl,--no-as-needed\2/g'$ORACLE_HOME/network/lib/env_network.mk

sed-i's/^\(ORACLE_LINKLINE.*\$(ORACLE_LINKER)\)\(\$(PL_FLAGS)\)/\1-Wl,--no-as-needed\2/g'$ORACLE_HOME/rdbms/lib/env_rdbms.mk

sed-i's/^\(\$LD\$LD_RUNTIME\)\(\$LD_OPT\)/\1-Wl,--no-as-needed\2/g'$ORACLE_HOME/bin/genorasdksh

sed-i's/^\(\s*\)\(\$(OCRLIBS_DEFAULT)\)/\1-Wl,--no-as-needed\2/g'$ORACLE_HOME/srvm/lib/ins_srvm.mk

然后在图形界面点击‘Retry’就能继续安装了。

下面的安装过程就没有什么问题了。

5.13.安装成功

最后应该就顺利完成了,按照安装程序提示最后执行两个脚本:

sudo/opt/oracle/oraInventory/orainstRoot.sh

sudo/opt/oracle/Oracle11gee/product/11.2.0/dbhome_1/root.sh

就完成了全部的安装。

可以通过https:

//localhost:

1158/em进行网络访问了。

6.SHELL编程

6.1.批量导出ORALCE表

batchExpdb内容

#!

/bin/bash

source/usr/lizq1/configtable

echo'要导出以下表:

'

echo$tables

echo'开始导出表:

'

forvarin$tables

do

echo$var

expdpyuchengtech/38854734tables=${var}dumpfile=${var}.dmplogfile=${var}.logdirectory=dir_db

done

echo'导出结束'

Configtable文件内容如下

tables="table1table2table3testtesttabletest_config"

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 文学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1