如果数据库备份文件过大,我们可能通过Oracle exp命令进行分段逻辑备份。这样如果分段备份exp语句过长而容易出现语句换行错误,最终导致后面的参数没有输入到Oracle中。也就是说,备份没有按分段方式导出数据。
针对这个问题,如果不想把所有的内容都放在一行内,那么可以考虑将用户名密码以外的参数放在parfile中,这个文件可以任意的分行。把备份脚本变成exp system/systemparfile=yourparfile即可。具体案例如下:[@more@]
原有脚本内容:
-bash-3.00$ more expdb_monthly.sh
. /export/home/oracle/.bash_profile
exp system/onewaveowner=A,B,C,D,E,Ffile=/backup/bak_1.dmp,/backup/bak_2.dmp,/backup/bak_3.dmp log=/backup/monthlybak.log direct=yfilesize=35000M statistics=none
改进后的脚本内容:
-bash-3.00$ more expdb_monthly.sh
. /export/home/oracle/.bash_profile
exp system/system parfile=expdb_monthly.par
-bash-3.00$ more expdb_monthly.par
owner=A,B,C,D,E,F
file=/backup/bak_1.dmp,/backup/bak_2.dmp,/backup/bak_3.dmp
log=/backup/monthlybak.log direct=yfilesize=35000M statistics=nonebuffer=20480000 recordlength=65534
最后两个参数来提高导出的效率buffer=20480000 recordlength=65534
测试补充:在原来脚本中,也尝试过通过Unix换行符“”来决绝长行问题,但是测试没有成功,当时的源文件内容如下:
-bash-3.00$ more expdb_monthly.sh
. /export/home/oracle/.bash_profile
exp system/onewaveowner=A,B,C,D,E,F
file=/backup/bak_1.dmp,/backup/bak_2.dmp,/backup/bak_3.dmp
log=/backup/monthlybak.log direct=yfilesize=35000M statistics=none