oracle备份表回滚脚本imp,Oracle备份与恢复总结 1-exp/imp (导出与导入 装库与卸库) 5/5 问题与脚本...

1.4常见问题

1字符集问题

ORACLE多国语言设置是为了支

持世界范围的语言与字符集,一般对语言提示,货币形式,排序方式和CHAR,VARCHAR2,CLOB,LONG字段的数据的显示等有效。ORACLE

的多国语言设置最主要的两个特性就是国家语言设置与字符集设置,国家语言设置决定了界面或提示使用的语言种类,字符集决定了数据库保存与字符集有关数据

(如文本)时候的编码规则。

ORACLE字符集设定,分为数据

库字符集和客户端字符集环境设置。在数据库端,字符集在创建数据库的时候设定,并保存在数据库props$表中。

在客户端的字符集环境比较简单,主

要就是环境变量或注册表项NLS_LANG,注意NLS_LANG的优先级别为:参数文件

使用一点点技巧,就可以使导出/导入在不同的字符集的数据库上转换数据。这里需要一个2进制文件编辑工具即可,如uedit32。用编辑方

式打开导出的dmp文件,获取2、3字节的内容,如00

01,先把它转换为10进制数,为1,使用函数NLS_CHARSET_NAME即可获得该字符集:

SQL> select nls_charset_name(1) from dual;

NLS_CHARSET_NAME(1)

-------------------

US7ASCII

可以知道该dmp文件的字符集为US7ASCII,如果需要把该dmp文件的字符集换成ZHS16GBK,则需要用

NLS_CHARSET_ID获取该字符集的编号:

SQL> select nls_charset_id('zhs16gbk') from dual;

NLS_CHARSET_ID('ZHS16GBK')

--------------------------

852

把852换成16进制数,为

354,把2、3字节的00 01换成03

54,即完成了把该dmp文件字符集从us7ascii到zhs16gbk的转化,这样,再把该dmp文件导入到zhs16gbk字符集的数据库就可以

了。

2版本问题

Exp/Imp很多时候,可以跨版本使用,如在版本7与版本8之间导出导入数据,但这样做必须选择正确的版

本,规则为:

·总是使用IMP的版本匹配数据库的版本,如果要导入到816,则使用816的导入工具。

·总是使用EXP的版本匹配两个数据库中低的那个版本,如在815与816之间互导,则使用815的EXP

工具。

imp和exp版本不能往上兼容:imp可以导入低版本exp生成的文件, 不能导入高版本exp生成的文件

1.5脚本

UNIX下ORACLE数据库通过PIPE管道进行备份

###UNIX下ORACLE数据库通过

PIPE管道进行备份

###### using "export"

and "tar" command to bakup oracle datebase #######

trap "" 1 #nohup

LOGFILE=/opt/bakup/log/bakup_ora.log

export LOGFILE

DUMPDIR=/archlog_node1

export DUMPDIR

exec >$LOGFILE

2>&1

echo

echo 'Begin at '`date`

echo

#clear old result file

cd $DUMPDIR

if [ -f exp.dmp.Z ]

then

echo "clear old result file"

rm exp.dmp.Z

fi

#make pipe

mkfifo exp.pipe

chmod a+rw exp.pipe

#gain the dmp.Z file

compress <

exp.pipe > exp.dmp.Z &

su -u oracle -c "exp

userid=ll/ll file=$DUMPDIR/exp.pipe full=y buffer=2000000

0"

echo

echo 'exp end at '`date`

echo

#rm pipe

rm exp.pipe

#tar the dmp.Z file to tape

mt -f /dev/rmt/0 rew

tar cvf /dev/rmt/0

exp.dmp.Z

echo

echo 'tar end at '`date`

echo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值