找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 20283|回复: 3

[文件操作] BAT脚本oracle expdp如何实现按周一至日备份最近7天?

[复制链接]
发表于 2022-4-11 14:47:24 | 显示全部楼层 |阅读模式
各位大神好,我想实现oracle expdp备份dmp按周一、二、三、四、五、六、日进行循环备份,保留最近一周的文件。
大概的思路是expdp导出的dmp文件命名规则是xxx.周一.dmp,xxx.周二.dmp,xxx.周三.dmp...xxx.周日.dmp
Bat批处理执行导出时先判断导出目录是否存在同名文件,如果存在则先删除,删除后在执行导出。
以下是expdp的导出命令
  1. expdp SEC_AAA/SEC_AAA@WMS DIRECTORY=dmpsecdir DUMPFILE=SEC_AAA.dmp logfile=SEC_SKP.log schemas=SEC_AAA
  2. expdp WMS_AAA/WMS_AAA@WMS DIRECTORY=dmpwmsdir DUMPFILE=WMS_AAA.dmp logfile=WMS_AAA.log schemas=WMS_AAA
复制代码
其他配置如导出目录都已在Oracle数据库中配好,谁能帮忙提供下实现的脚本内容?小弟在此感激不尽,万分感谢!
发表于 2022-4-11 14:58:25 | 显示全部楼层
  1. for /f "tokens=2" %%i in ("%date%") do (
  2. if exist *.%%i.dmp del *.%%i.dmp
  3. expdp SEC_SKP/SEC_SKP@WMS DIRECTORY=dmpsecdir DUMPFILE=SEC_SKP.%%i.dmp logfile=SEC_SKP.%%i.log schemas=SEC_SKP
  4. expdp WMS_SKP/WMS_SKP@WMS DIRECTORY=dmpwmsdir DUMPFILE=WMS_SKP.%%i.dmp logfile=WMS_SKP.%%i.log schemas=WMS_SKP
  5. )
复制代码
 楼主| 发表于 2022-4-11 16:43:35 | 显示全部楼层
回复 2# idwma


    你好,感谢您提供的脚本,我测试后生成的文件是乱码名称SEC_SKP.鍛ㄤ竴和WMS_SKP.鍛ㄤ竴.DMP这种,您看下怎么修改呢?
发表于 2022-4-11 17:57:00 | 显示全部楼层
  1. chcp 65001
  2. for /f "tokens=1" %%i in ("%date%") do (
  3. if exist *.%%i.dmp del *.%%i.dmp
  4. expdp SEC_SKP/SEC_SKP@WMS DIRECTORY=dmpsecdir DUMPFILE=SEC_SKP.%%i.dmp logfile=SEC_SKP.%%i.log schemas=SEC_SKP
  5. expdp WMS_SKP/WMS_SKP@WMS DIRECTORY=dmpwmsdir DUMPFILE=WMS_SKP.%%i.dmp logfile=WMS_SKP.%%i.log schemas=WMS_SKP
  6. )
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-20 04:32 , Processed in 0.018953 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表