bat批处理异备文件、压缩文件
sql server异备相关参考:https://blog.csdn.net/rznice/article/details/7742720
1、压缩复制
压缩本地文件,并把压缩后的文件复制到其他机器
net use Z: \\192.168.135.1\share_linux a123456! /user:chaoqun.guo
set bath=c:\backup\
set today=%date:~0,4%%date:~5,2%%date:~8,2%
::%date:~0,4%,表示从第0下标开始获取4位长度的值
set db_name=test
set filename=%db_name%%today% path="C:\Program Files\WinRAR"
winRAR a %bath%%filename%.rar %bath%%filename%.bak copy %bath%%filename%.rar \\192.168.135.1\share_linux /Y net use \\192.168.135.1\share_linux /delete
在sql server中操作net use
EXEC sp_configure 'show advanced options',1;
RECONFIGURE WITH OVERRIDE;
EXEC sp_configure 'xp_cmdshell',1;
RECONFIGURE WITH OVERRIDE
EXEC master.dbo.xp_cmdshell 'net use x: \\219.129.239.217\master_1_temp "AO%7Ro*AD35@bTa" /user:"7RoAdmin"'
删除net use 盘
net use z: /delete /y
2、数据库备份压缩
写的是批处理的语句,每天调用,压缩删除原文件。
首先写下路径,先将压缩软件的路径写入系统的环境变量里,加入到path中。比如将“C:\Program Files\WinRAR\”加入到path中。或者直接在bat中path="C:\Program Files\WinRAR\"。
之后批处理中写好相应的处理命令:
rar a -df %filename%.rar %filename%.dmp
举个例子: 建立一个批处理BackFav.bat(名字可以随便起)文件内容:
REM 这个批处理文件是用来自动备份我的收藏夹
REM WinRAR <命令> -<开关1> -<开关N> <压缩文件> <文件> <@列表文件> <解压路径\>
"D:\Program Files\WinRAR\WinRAR.exe" a -as -r -sfx -zsfxpara.txt -EP1 "d:\my documents\Favorites.exe" "%USERPROFILE%\Favorites"
===================================================
参数说明:
a: 添加指定的文件(源目录,这里是"%USERPROFILE%\Favorites")和文件夹到压缩文件(目标文件,这里是"d:\my documents\Favorites.exe")中。
-as: 这是一个开关,指添加方式是“同步压缩文件内容”
-r: 表示“包含子文件夹”
-sfx: 表示建立的是一个自解压文件
-zsfxpara.txt: 从文件sfxpara.txt读取压缩文件注释,这注释有什么用后面解释
-ep1: 表示不把路径%USERPROFILE%保存在压缩文件中
注释文件的作用
建立压缩文件的时候不光要考虑压缩那些文件,还要考虑怎么解压缩。通过注释文件可以向压缩包传递许多有用的信息。
sfxpara.txt内容:
PATH=%USERPROFILE%\
Silent=1
例:
"C:\Program Files\WinRAR\Rar.exe" a "g:\aa.rar" "f:\11.txt" 压缩"f:\11.txt"到G盘,命名为“aa”
"C:\Program Files\WinRAR\Rar.exe" d "g:\aa.rar" "22.bat" 删除压缩包"g:\aa.rar"中的"22.bat" 文件
"C:\Program Files\WinRAR\Rar.exe" d "g:\aa.rar" "ABC" 删除压缩包"g:\aa.rar"中的"ABC" 文件夹
批量压缩复制:
1.压缩指定的部分文件 复制代码
@echo off set year=%date:~0,4% set month=%date:~5,2% set day=%date:~8,2% set curdate=%year%%month%%day% for %%i in (D:\logs\logs\OmsAdmin.2016-%month%-*.log) do "C:\Program Files (x86)\WinRAR\winrar.exe" a -m5 -ibck D:\logs\log_%curdate%.rar %%i
复制代码
参数说明: (1) for语句支持通配符找文件,例如“OmsAdmin.2016-%month%-*.log” (2) for语法: for %%i in 集合 do 命令(%%i) (3) winrar语法:winrar a -m5 -ibck 生成的压缩文件存储路径 被压缩文件 其中,a : 压缩(e:解压) -m5:按照第5等级最大程度压缩 -ibck:后台运行 2.删除过期备份文件 forfiles /p D:\logs\logs /s /D -30 /c "cmd /c del @file"
参数说明: (1) forfiles通常用作对文件或文件夹的批处理, 其中,/p:开始搜索的路径 /s:递归到子目录 /D:文件最后修改的日期时间 +/-数字 3.复制文件 xcopy D:\from\log_%curdate%.rar D:\to\log_%curdate%.rar
sql server中,调用批处理与net use
/*
在 sql server中调用 net use
EXEC sp_configure 'show advanced options',1;
RECONFIGURE WITH OVERRIDE;
EXEC sp_configure 'xp_cmdshell',1;
RECONFIGURE WITH OVERRIDE
EXEC master.dbo.xp_cmdshell 'net use x: \\219.129.239.217\master_1_temp "AO%7Ro*AD35@bTa" /user:"7RoAdmin"'
*/ CREATE PROCEDURE [dbo].[Delete_File]
@day NVARCHAR(3),
@url NVARCHAR(100)
AS
BEGIN
DECLARE @sql NVARCHAR(MAX),@result INT
EXEC xp_fileexist 'C:\DEL.bat', @result OUTPUT --检查文件DEL.bat存在
IF @result=1
EXEC xp_cmdshell 'del C:\DEL.bat'
IF object_id('test','U')IS NOT NULL --检查test表是否存在
DROP TABLE test SET @sql='@echo off
setlocal enabledelayedexpansion
Rem 取'+@day+'天之前的日期,取回放入变量riqi
echo wscript.echo dateadd("d",-'+@day+',date) >%tmp%\tmp.vbs
for /f "tokens=1,2,3* delims=-" %%i in (''cscript /nologo %tmp%\tmp.vbs'') do set y=%%i&set m=%%j&set d=%%k
if %m% LSS 10 set m=0%m%
if %d% LSS 10 set d=0%d%
set riqi=%y%%m%%d%
set "mulu='+@url+'"
for /f "eol= skip=4 tokens=1,4" %%a in (''dir /a-d /tw "%mulu%"^|find /v ^"字节^"'') do (
set delrq=%%a
set delrq=!delrq:-=!
if !delrq! lss %riqi% (
del /q "%mulu%\%%~nxb"
)
)
pause'
select @sql a INTO test --将批处理脚本放入test表
EXEC xp_cmdshell 'bcp "select top 1 a from test" queryout C:\DEL.bat -c -T -S127.0.0.1,2433' --将批处理文件导出到C盘根目录下
DROP TABLE test --删除test表
EXEC xp_cmdshell 'C:\DEL.bat'--调用批处理文件
END
3、参考文件
--开启xp_cmdshell,一次性
--sp_configure 'show advanced options',1
--reconfigure
--go
--sp_configure 'xp_cmdshell',1
--reconfigure
--go --服务器D盘根目录放winrar文件夹
--运行本sql:局域网共享文件夹存放生成的今天的备份文件,如果存在昨天的备份文件压缩成功后删除源文件,留压缩文件
--解压密码为123
--替换msdb为你要备份的数据库,文件局域网共享文件夹用户名密码ip或者计算机名 exec master..xp_cmdshell 'net use v: \\192.168.18.16\FormStudio "88888888" /user:192.168.18.16\administrator /y' declare @filename varchar(200)
set @filename='v:\msdb'+convert(varchar,getdate(),112)+'.bak' --设置备份文件的路径和文件名
print @filename
backup database[msdb] to disk=@filename with
NOINIT,NOUNLOAD,NAME='backup',NOSKIP,STATS=10,NOFORMAT --执行备份 DECLARE @file varchar(200),
@retval int,
@param1 int,
@s varchar(200)
set @s='v:\msdb'+convert(varchar,getdate()-1,112)+'.bak'
set @file='D:\WinRAR\winrar.exe a -ep -m5 -p123 -df v:\msdb'+convert(varchar,getdate()-1,112)+'.rar v:\msdb'+convert(varchar,getdate()-1,112)+'.bak' --将压缩备份文件并删除源文件的winrar命令行命令
EXECUTE @retval=master..xp_fileexist @s, @param1 OUTPUT
IF @param1 = 0
PRINT 'File does not exist!'
ELSE
exec master..xp_cmdshell @file --执行命令 exec master..xp_cmdshell 'net use v: /delete'
4.我的实践
::insert db record
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;insert into db_mart..ddtupload_log(count_date) values(getdate())" ::init
set dir=Db_Tank_Back
if exist F:\%dir% (set disk=F:\) else if exist E:\%dir% (set disk=E:\) else (set disk=D:\) set old_filename=Db_Tank_Copy%date:~9,1%.bak
set new_filename=Db_Tank_Copy_%date:~0,4%%date:~5,2%%date:~8,2%.7z
set log_file=C:\shell\bat\backup_log.txt
set temp_file=C:\shell\bat\gameZoneName.txt
set path=%disk%%dir%\
echo %date%%time%>>%log_file% ::compress
::cd d:\ddt_tool\
d:
cd d:\ddt_tool\
7za.exe a %path%%new_filename% %path%%old_filename%
if exist %path%%new_filename% (echo compress success >>%log_file%) else (echo compress fail>>%log_file%) ::net use
if exist T:\ (@echo T disk ok) else (net use T: \\192.168.221.92\d$ "7RoAd#*(=-=)#!" /user:"7RoAdmin") ::mkdir
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;select '香港易游(1-2-4)' from db_gms..v_gameZoneName_Version;">%temp_file%
for /f "skip=2" %i in (%temp_file%) do set mkdir=%i
if exist t:\Db_Tank_Back\%mkdir% (@echo t:\%mkdir% ok) else (mkdir t:\Db_Tank_Back\%mkdir%)
cd \ ::copy file
set new_path=t:\Db_Tank_Back\%mkdir%\
copy %path%%new_filename% %new_path% /y
if exist %new_path%%new_filename% (echo backup success >>%log_file%
c:
cd C:\Program Files\Microsoft SQL Server\90\Tools\binn\
sqlcmd -A -Q"set nocount on;update db_mart..ddtupload_log set isok = 1, upload_date = getdate() where convert(char(10),count_date,120) = convert(char(10),getdate(),120);"
) else (echo backup fail >>%log_file%) pause
5.快速把bat脚本安装成定时任务
/*
--ddt_db_backup_install.bat @echo off
color 2
echo.
echo ----------------- ddt_db_backup_install --------------------
echo ----------------- ddt_db_backup_install -------------------- > install.log
echo. schtasks /delete /TN ddt_db_backup /F
schtasks /delete /TN ddt_db_bakcup /F
schtasks /create /ru SYSTEM /tn "ddt_db_backup" /tr "C:\shell\ddt_db_bakcup.bat" /sc daily /st 06:10:00 /F IF ERRORLEVEL 1 (ECHO Error: ddt_db_backup install error
ECHO Error: ddt_db_backup install error >> install.log 2>&1
goto error)
echo OK
echo OK >> install.log 2>&1 :ok
echo.
echo ------------------- Install Success ---------------------
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
goto end :error
echo.
echo.
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
ping -n 2 127.1>nul
exit 1 :end
exit */ /*
--ddt_db_backup.bat
--add the code for delete override files if exist F:\Db_Tank_Back (set data_path=F:\Db_Tank_Back) else if exist E:\Db_Tank_Back (set data_path=E:\Db_Tank_Back) else (if exist D:\Db_Tank_Back (set data_path=D:\Db_Tank_Back) )
forfiles /p %data_path% /s /m *.7z /d -7 /c "cmd /c del @path" */
附: 压缩参数
用法: rar <命令> -<开关 1> -<开关 N> <压缩文件> <文件...>
<@列表文件...> <解压路径\> <注释>
a 添加文件到压缩文件
c 添加压缩文件注释
cf 添加文件注释
ch 更改压缩文件参数
cw 写入压缩文件注释到文件
d 删除压缩文件中的文件
e 解压压缩文件到当前目录
f 刷新压缩文件中的文件
i[参数]=<串> 在压缩文件中查找字符串
k 锁定压缩文件
l[t,b] 列出压缩文件[技术信息,简洁]
m[f] 移动到压缩文件[仅对文件]
p 打印文件到标准输出设备
r 修复压缩文件
rc 重建丢失的卷
rn 重命名压缩文件
rr[N] 添加数据恢复记录
rv[N] 创建恢复卷
s[名字|-] 转换压缩文件为自解压格式或反之
t 测试压缩文件
u 更新压缩文件中的文件
v[t,b] 详细列出压缩文件[技术信息,简洁]
x 用绝对路径解压文件 <开关>
- 停止扫描
ac 压缩或解压后清除存档属性
ad 添加压缩文件名到目标路径
ag[格式] 使用当前日期生成压缩文件名
ao 添加具有存档属性的文件
ap<路径> 添加路径到压缩文件中
as 同步压缩文件内容
av 添加用户身份校验 (仅注册版)
av- 禁用用户身份校验
c- 禁用注释显示
cfg- 禁用读取配置
cl 名称转换为小写
cu 名称转换为大写
df 压缩后删除文件
dh 打开共享文件
ds 对固实压缩文件禁用名称排序
e[+]<属性> 设置文件排除和包括属性
ed 不添加空目录
en 不添加"压缩文件结束"标志
ep 从名称中排除路径
ep1 从名称中排除基本目录
ep2 展开为完整路径
ep3 扩展路径为包含盘符的完全路径
f 刷新文件
hp[密码] 同时加密文件数据和文件头
id[c,d,p,q] 禁用信息显示
ieml[地址] 邮寄压缩文件
ierr 发送所有消息到标准错误设备
ilog[名称] 把错误写到日志文件 (仅注册版)
inul 禁用所有消息
ioff 完成一个操作后关闭 PC 电源
isnd 启用声音
k 锁定压缩文件
kb 保留损坏的已解压文件
m<0..5> 设置压缩级别(0-存储...3-默认...5-最大)
mc<参数> 设置高级压缩参数
md<大小> 以KB为单位的字典大小(64,128,256,512,1024,2048,4096 or A-G)
ms[ext;ext] 指定存储的文件类型
mt<线程> 设置线程数
n<文件> 仅包括指定文件
n@ 从标准输入设备读取要包括的文件名称
n@<列表> 在指定列表文件包括文件
o+ 覆盖已存在文件
o- 不覆盖已存在文件
oc 设置 NTFS 压缩属性
or 自动重命名文件
os 保存 NTFS 流
ow 保存或恢复文件所有权和组
[密码] 设置密码
p- 不询问密码
r 包含子目录
r0 仅包含通配符名称的子目录
ri<P>[:<S>] 设置优先级 (0-默认,1-最小..15-最大) 和休眠时间(毫秒)
rr[N] 添加数据恢复记录
rv[N] 创建恢复卷
s[<N>,v[-],e] 创建固实压缩文件
s- 禁用固实压缩文件
sc<chr>[obj] 指定字符集
sfx[名称] 创建自解压文件
si[名称] 从标准输入设备读取数据
sl<大小> 处理小于指定大小的文件
sm<大小> 处理大于指定大小的文件
t 压缩后测试文件
ta<日期> 添加日期 <日期> 后修改的文件,日期格式 YYYYMMDDHHMMSS
tb<日期> 添加日期 <日期> 前修改的文件,日期格式 YYYYMMDDHHMMSS
tk 保留原始压缩文件时间
tl 设置压缩文件时间为最新时间
tn<时间> 添加 <时间> 以后的文件
to<时间> 添加 <时间> 以前的文件
ts<m,c,a>[N] 保存或恢复文件时间(修改,创建,访问)
u 更新文件
v 自动检测创建卷的大小或者列出所有的卷
v<大小>[k,b] 创建卷大小=<大小>*1000 [*1024, *1]
vd 创建卷前清除磁盘内容
ver[n] 文件版本控制
vn 使用旧样式卷命名方案
vp 每卷之前暂停
w<路径> 指定工作目录
x<文件> 排除指定的文件
x@ 从标准输入设备读取要排除的文件名
x@<列表> 排除指定列表文件中的文件
y 假设对全部询问都回答是
z[文件] 从文件读取压缩文件注释
bat批处理异备文件、压缩文件的更多相关文章
- linux打包文件,压缩文件
1.打包: linux下最常用的打包程序就是tar了,使用tar程序打出来的包我们常称为tar包,tar包文件的命令通常都是以.tar结尾的.生成tar包后,就可以用其它的程序来进行压缩. 1.命令格 ...
- 【bat批处理】批量执行某个文件夹下的所有sql文件bat批处理
遍历文件夹下所有的sql文件,然后命令行执行 for /r "D:\yonyou\UBFV60\U9.VOB.Product.Other" %%a in (*.sql) do ( ...
- Shell Script编程——USB挂载/复制文件/查找文件/压缩文件
PS:$引用变量的时候不要加空格.用了case,while的结构. main文件 #!/bin/bash chmod a+x changedate chmod a+x changemod chmod ...
- 分享一个ASP.NET 文件压缩解压类 C#
需要引用一个ICSharpCode.SharpZipLib.dll using System; using System.Collections.Generic; using System.Linq; ...
- 计算机程序的思维逻辑 (64) - 常见文件类型处理: 属性文件/CSV/EXCEL/HTML/压缩文件
对于处理文件,我们介绍了流的方式,57节介绍了字节流,58节介绍了字符流,同时,也介绍了比较底层的操作文件的方式,60节介绍了随机读写文件,61节介绍了内存映射文件,我们也介绍了对象的序列化/反序列化 ...
- Java编程的逻辑 (64) - 常见文件类型处理: 属性文件/CSV/EXCEL/HTML/压缩文件
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...
- Linux系统下文件压缩与打包命令
Linux系统下文件压缩与打包命令 常用的压缩文件拓展名 * .Z * .zip * .gz * .bz2 * .xz * .tar * .tar.gz * .tar.bz2 * .tar.xz 压缩 ...
- Windows中的权限设置、文件压缩、文件加密、磁盘配额和卷影副本
目录 权限设置 文件夹的NTFS权限 文件的NTFS权限 NTFS权限的应用规则 文件压缩 文件加密 磁盘配额 卷影副本 权限设置的应用 遇到的一个权限问题的小bug 权限问题的实际应用 权限设置 ...
- linux命令行快速统计文件(压缩文件)的行数
统计(文件|压缩文件)的行数 zcat file.gz | sed -n '$=' #迅速.直接打印出多少行.-n 取消 ...
随机推荐
- am335x 一个按键实现重置 ip 和 root passwd
* 其实做法很简单,我连按键驱动都没有去写,读取 gpio 的值然后 拷贝了一份 /etc/network/interfaces_bak 为 interfaces ,用脚本重新设置了一次root 密码 ...
- SHLVL--shell终端深度
参考:How And Why You Would Use The $SHLVL Variable SHLVL代表shell打开的深度,进程第一次打开shell时$SHLVL=1,然后在此shell中再 ...
- 关于对象序列化json 说说
下面一个json格式图(说一下,json 其实就是js 数组和对象的一种字符串表现形式 var obj=[] 或者var obj={} ) var json= {} 如下 从图中看 json中有两个 ...
- 【NOIP模拟题】Permutation(dp+高精度)
首先我们可以这样想: 设状态f[i, j]表示1-i序列有j个'<'的方案数 那么考虑转移 因为i比i-1大,所以可以考虑从i-1来转移.首先i是要插入1-i-1这个序列的,所以我们可以思考插入 ...
- hdu 1358:Period(KMP算法,next[]数组的使用)
Period Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- jQuery实现瀑布流布局详解(PC和移动端)
首先我们将如下样式的若干个单元写进body中,并将“box”向左浮动: <div class="box"> <img class="img" ...
- POJ2139 Six Degrees of Cowvin Bacon [Floyd]
水题,随手敲过 一看就是最短路问题,a,b演同一场电影则他们的距离为1 默认全部两两原始距离无穷,到自身为0 输入全部数据处理后floyd 然后照它说的求平均分离度 再找最小的,×100取整输出 #i ...
- XCODE5 真机測试
原文地址: http://my.oschina.net/u/1245365/blog/196420 亲測 可用 ios申请真机调试( xcode 5)具体解析 摘要 我们做ios项目时.模拟器仅仅能 ...
- java基础---->java自带的xml解析
在查看公司框架的源码的时候,发现框架用的是jdk自带的xml解析.今天,想着对它总结一下.从未放弃过爱你,只是从浓烈变得悄无声气. 利用jdk自带的xml创建文档 一. CreateXmlFile类如 ...
- HYSBZ 1036(树的统计Count)
题目链接:传送门 题目大意:中文题,略 题目思路:树链剖分裸题. 闲谈:树链越练越熟练了 #include <iostream> #include <cstdio> #incl ...