Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx
- 文档编号:9892361
- 上传时间:2023-02-07
- 格式:DOCX
- 页数:14
- 大小:21.74KB
Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx
《Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx》由会员分享,可在线阅读,更多相关《Ubuntu环境利用ORALCE数据泵批量导出数据库表.docx(14页珍藏版)》请在冰豆网上搜索。
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"
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Ubuntu 环境 利用 ORALCE 数据 批量 导出 数据库
![提示](https://static.bdocx.com/images/bang_tan.gif)