使用.bat将mysql中的日志文件拷贝到指定目录中出来(根据当前日期存放)

该博客介绍了如何使用批处理脚本来自动化复制MySQL的日志文件到指定目录,并根据当前日期创建子目录进行组织。脚本首先定义了目标盘符和目录,然后检查目标盘符是否存在,如果不存在则创建。接着,它会获取当前日期并创建相应的子目录。最后,脚本遍历当前目录下所有以'binlog.'开头的文件并将它们复制到新创建的日期目录中。
摘要由CSDN通过智能技术生成
1.打开mysql的日志保存目录地址,如D:\phpstudy_pro\Extensions\MySQL8.0.12\data
2.新建copy_log.txt文件,在文件中写入
@echo off
:: 存放的盘符
set Pan=d:\
:: 存放的目录
set MysqlBf=mysqlbf\
:: 获取当前日期(年月日)
set CURRENT_DATE_STRING=%date:~0,4%%date:~5,2%%date:~8,2%
:: 检测当前盘符是否存在
if exist %Pan% (
    echo %Pan% is success
    :: 判断d:/mysqlbf目录不存在创建
    if not exist %MysqlBf% md %Pan%%MysqlBf%
    if not exist %CURRENT_DATE_STRING% md %Pan%%MysqlBf%%CURRENT_DATE_STRING%

    :: 将数据mysql日志保存到改目录中
    for /r %%a in (binlog.*) do copy %%a %Pan%%MysqlBf%%CURRENT_DATE_STRING%
) else (
    echo !!
    echo !!%Pan% does not exist
    echo !!
)


pause

参考1:https://blog.csdn.net/u012178002/article/details/111827280

@echo off
for /r %%a in (binlog.*) do copy %%a D:\1
pause

(1)for /r主要用于搜索指定路径及其所有子目录中符合要求的文件(/r后如果没有指定目录,则使用当前目录)
(2)上述例子实现将脚本所在目录下后缀为txt的文件复制到目录D:\1中
(3)批处理当中的 for 循环的结构:for in do。%%a 为变量,/r 为递归方式,in 与 do 之间一定要有 ()。
(4)for 循环的工作流程:查找当前文件夹及其子文件夹里面的 txt 文件,找到后把文件路径赋值给变量 %%a,然后执行 do 后面的语句,直到遍历完全部文件。

参考2:判断文路径是否存在,若不存在就创建

判断文件夹是否存在,若不存在就创建一个
如判断 folder 文件夹是否存在,bat脚本如下:

@echo on
@title 批处理判断文件夹是否存在

if exist folder (
   echo "文件存在"
) else (
::创建文件夹
md folder 
)

timeout /nobreak /t 100 >nul

或者:

@echo on

if not exist folder md folder

timeout /nobreak /t 100 >nul

参考3:bat命令获取当前时间日期

:: 关闭终端回显
@echo off

set CURRENT_DATE_STRING=%date:~0,4%%date:~5,2%%date:~8,2%
echo CURRENT_DATE_STRING=%CURRENT_DATE_STRING%
set CURRENT_TIME_STRING=%time:~0,2%_%time:~3,2%_%time:~6,2%
echo CURRENT_TIME_STRING=%CURRENT_TIME_STRING%
set CURRENT_DATE_TIME_STRING=%CURRENT_DATE_STRING%_%CURRENT_TIME_STRING%
echo CURRENT_DATE_TIME_STRING=%CURRENT_DATE_TIME_STRING%

:: 创建文件夹
md %CURRENT_DATE_TIME_STRING%
pause

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值