博客
关于我
oracle使用批处理文件expdp定时备份
阅读量:353 次
发布时间:2019-03-04

本文共 2245 字,大约阅读时间需要 7 分钟。

bat文件:

@echo off echo ================================================ echo  Windows环境下Oracle数据库的自动备份脚本echo  1. 使用当前日期命名备份文件。echo ================================================::对应用户名set USER=QXXXXX::对应用户的密码set PASSWORD=QXXXXX::导出数据(根据日期加时分秒来命名备份文件)expdp %USER%/%PASSWORD% directory=qmysptbackup dumpfile=yxhl_%date:~0,4%%date:~5,2%%date:~8,2%%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%.dmp logfile=yxhl_%date:~0,4%%date:~5,2%%date:~8,2%%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%.log schemas=%USER%::如果报错LRM-00112: 参数'logfile'不允许有多个值。 则是上面时间格式输出有问题,有空格,输出了两个值,加上下划线_ 即可 (在date和time之间加下划线 )::yxhl_%date:~0,4%%date:~5,2%%date:~8,2%_%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%.log

改成bat格式,添加到任务计划中,脚本的前提设置:

创建逻辑目录:

SQL> create directory data_dir as '/home/oracle/dmp/user';Directory created.

用sys管理员给你的指定用户赋予在该目录的操作权限。/ directory赋权

SQL> grant read,write on directory data_dir to user;Grant succeeded.

执行后的结果:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

还有值得注意的是,这个directory的值,要去到Oracle里面改。

create or replace directory dumpdir as '/home/dumpfiles';

直接在外面bat里面改是不对的,,,

在这里插入图片描述

参考:

https://www.cnblogs.com/promise-x/p/7477360.html
https://mhl.xyz/Oracle/directory.html
https://www.cnblogs.com/luck666/p/10253686.html

分割线===

关于删除的:
shell:

find /data01/backup/ -mtime +15 -name "user*.dump" -exec rm -rf {   } \;  #删除前15天的数据#find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} \

powershell:

set DATADIR=F:\app\Administrator\admin\orcl\dpdump\::删除7天前的备份。  forfiles /p %DATADIR% /s /m HBGYDX*.DUMP /d -7 /c "cmd /c del @path"

今天碰到个docker环境的,纯净的dockerfile。没有find指令的。要删除30天之前的文件

delFile.sh

#!/bin/bash#创建文本for i in `seq 1 40`do        touch `date -d "-$i day" +%Y%m%d`.txtdone#删除过去30天的文件   20201010  今天20201109before30Day=$(date -d "-30 day" +%Y%m%d)for i in `ls *.txt`do	# ${i:0:8}截取前8位 , if里面双方变量要加双引号,否则报错        if [ "${i:0:8}" -le "$before30Day" ];then                echo "该文件是30天之前的: $i"                #rm -f $i        fidone

在这里插入图片描述

另一个人的写法:

在这里插入图片描述

2021年2月19日11:50:10

另说一个另一个格式的。照葫芦画瓢

xx-logstssh-2021.01.29.logxx-logstssh-2021.02.09.log
#!/bin/bashbefore7Day=$(date -d "-7 day" +%Y%m%d)for i in `ls *.log`do		#sed不支持pcre表达,比如 \d        compareDate=`echo $i | sed -r 's#.*([0-9]{4})\.([0-9]{2})\.([0-9]{2}).*#\1\2\3#'`        if [ "$compareDate" -lt "$before7Day" ];then                echo "该文件是7天之前的: $i"                #rm -f $i        fidone

在这里插入图片描述

你可能感兴趣的文章
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
MySQL学习笔记十七:复制特性
查看>>
Mysql学习第一课-mysql的定义及sql语句
查看>>
mysql安全模式: sql_safe_updates
查看>>
mysql安装,卸载,连接
查看>>
MySQL安装之没有配置向导
查看>>
mysql安装出现 conflicts with mysql*的解决办法
查看>>