作业备份-存储过程
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | USE [database] GO /****** Object: StoredProcedure [dbo].[bp_sys_DatabaseBackup] Script Date: 01 /04/2025 18:08:44 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- exec bp_sys_DatabaseBackup 'E:\DATABACKUP' ,null,2 ALTER PROCEDURE [dbo].[bp_sys_DatabaseBackup] @Path varchar(255), @days int , --自动删除数据库天数 @BackupMode int=1 --1默认数据库备份;2-日志备份 AS declare @intRetval int declare @strMessage varchar(255) declare @BakFile varchar(255) declare @database varchar(255) DECLARE @ date datetime set @intRetval=0 set @Path=isnull(@Path, 'D:\DATABACKUP' ) set @database=DB_NAME() --先清除备份文件 --目录名必须设置正确,否则会容易造成清除不成功,导致硬盘爆满 SET @days=ISNULL(@days,30) SET @ date =DATEADD(day,-@days,GETDATE()) EXECUTE master.dbo.xp_delete_file 0,@Path,N 'bak' ,@Date BEGIN TRY IF @BackupMode =1 BEGIN SET @BakFile=@Path+ '\'+@database+replace(replace(replace(convert(varchar(30),getdate(),120),' ',' '),' - ',' '),' : ',' ')+' .bak' BACKUP DATABASE @database TO DISK = @BakFile WITH NOFORMAT, NOINIT, NAME =@database , SKIP, NOREWIND, NOUNLOAD, STATS = 10 INSERT INTO [xs_DatabaseBackupLog](DBName,BackupFile,BackupTime,Status,Remark) SELECT @database,@BakFile,getdate(),1, '数据库备份成功' END IF @BackupMode=2 BEGIN PRINT '开始日志备份...' --追加到最近一个文件里 SELECT TOP 1 @BakFile=BackupFile FROM xs_databasebackuplog WHERE BackupTime>dateadd(day,-7,getdate()) AND Status=1 ORDER BY ID DESC -- SET @BakFile=@Path+ '\'+@database+replace(replace(replace(convert(varchar(30),getdate(),120),' ',' '),' - ',' '),' : ',' ')+' Log.bak' BACKUP LOG @database TO DISK = @BakFile WITH NOFORMAT, NOINIT, NAME = @database, SKIP, NOREWIND, NOUNLOAD, STATS = 10 INSERT INTO [xs_DatabaseBackupLog](DBName,BackupFile,BackupTime,Status,Remark) SELECT @database,@BakFile,getdate(),1, '日志备份成功' END END TRY BEGIN CATCH IF ERROR_NUMBER()>0 BEGIN set @strMessage= '备份失败!' +ERROR_MESSAGE() INSERT INTO [xs_DatabaseBackupLog](DBName,BackupFile,BackupTime,Status,Remark) SELECT @database,null,getdate(),0,@strMessage GOTO QUIT END END CATCH QUIT: RETURN @intRetval |
作业
1 2 3 | use [ database ] exec bp_sys_DatabaseBackup 'G:\Databackup\LQtexRyb' ,1 go |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
2022-01-04 kubelet组件功能