Oracle数据导入导出,定时备份

本文详细介绍了如何使用Oracle数据导入导出命令行工具进行数据备份,并提供了创建Windows定时任务进行定期备份的方法。内容包括导出数据的expdata.bat和impdata.bat批处理文件,以及设置定时备份的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 导出数据命令行
    文件 expdata.bat parfile指向expdata.par文件
    exp parfile=D:\exp\expdata.par file=txgl.dmp filesize=600M log=dl.log

    文件expdata.par
    <a target=_blank href="mailto:userid=txgl/123456@ZZSorcl">userid=txgl/123456@ZZSorcl</a>
    buffer=8192000
    compress=n
    grants=n
    
    
  2. 导入数据
    文件impdata.bat
    imp system/password@orcl fromuser=sntap touser=snt parfile=impdata.par
    


    文件impdata.par
    file=oraclebak.dmp
    buffer=2048000
    ignore=n
    commit=y
    

  3. 导入数据 不写par
    imp system/password@orcl fromuser=from_user touser=to_user file=E:\test\bak\test.dmp log=E:\test\bak\test.log buffer=2048000 ignore=y commit=y

    如果是不同的表空间,touser要一个权限,不然clob类型字段的表会出错:GRANT UNLIMITED TABLESPACE TO TO_USER

  4. Windows定时备份
    新建bat文件 内容:
    @echo off   
    echo 正在备份 Oracle 数据库,请稍等......   
    set riqi=%date:~0,4%%date:~5,2%%date:~8,2%
    exp system/password@orcl file=E:\oraclebak\oraclebak%riqi%.dmp log=F:\oraclebak\oraclebak%riqi%.log buffer=960000  
    echo 任务完成!
    echo 开始清理备份文件
    forfiles /p "E:\oraclebak" /s /m *.* /d -6 /c "cmd /c del @path"

    在window计划任务里面添加定时任务,设置备份的间隔时间,每天执行的时间,在“操作”选项卡里面选择新建好的bat文件。“常规”选项卡里面选择“不管用户是否登录都要运行”


-------------------------------------------------------------------------------------------------------------------------------------------
创建Oracle用户:

create user newuser
  identified by "password"
  --default tablespace TBS_DATA01 
  --temporary tablespaceTBS_DATA01_temp 
  profile DEFAULT
  --表空间
  quota unlimited on newuser;
-- Grant/Revoke role privileges
--用户
grant connect to newuser;
-- Grant/Revoke system privileges
grant create any index to newuser;
grant create any sequence to newuser;
grant create any table to newuser;
grant create any trigger to newuser;
grant create any view to newuser;
grant create procedure to newuser;
grant select any dictionary to newuser;
grant select any sequence to newuser;
GRANT UNLIMITED TABLESPACE TO newuser;


1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值