如果数据库备份文件过大,我们可能通过Oracle exp命令进行分段逻辑备份。这样如果分段备份exp语句过长而容易出现语句换行错误,最终导致后面的参数没有输入到Oracle中。也就是说,备份没有按分段方式导出数据。
针对这个问题,如果不想把所有的内容都放在一行内,那么可以考虑将用户名密码以外的参数放在parfile中,这个文件可以任意的分行。把备份脚本变成exp system/system parfile=yourparfile即可。具体案例如下:
[@more@]原有脚本内容:
-bash-3.00$ more expdb_monthly.sh
. /export/home/oracle/.bash_profile
exp system/onewave 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=y filesize=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=y filesize=35000M statistics=none buffer=20480000 recordlength=65534
最后两个参数来提高导出的效率 buffer=20480000 recordlength=65534
测试补充:在原来脚本中,也尝试过通过Unix换行符“”来决绝长行问题,但是测试没有成功,当时的源文件内容如下:
-bash-3.00$ more expdb_monthly.sh
. /export/home/oracle/.bash_profile
exp system/onewave 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=y filesize=35000M statistics=none
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/18841027/viewspace-1053635/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/18841027/viewspace-1053635/