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