亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

備份數據庫存儲過程

系統 2145 0
原文: 備份數據庫存儲過程

由于使用SSMS創建的維護計劃中,完整備份的話,會打斷別的備份的順序鏈,而由于管理原因,往往需要有幾套備份計劃,所以經過時間,本人編寫了一個存儲過程實現我的想法。不管你用不用,反正我用了。 偷笑


首先,創建一個表,用于記錄備份信息。因為用DMV和系統視圖的話往往要編寫很多東西,對于一般人很難記住那么多表。所以使用一個表來記錄更加方便。以前之前已經創建了一個庫 AuditDB,用于監控數據庫的DDL操作,所以這里沒有再編寫建庫腳本。只是在這個庫里面創建一個表。

    USE AuditDB

GO

IF OBJECT_ID('BackupHistory') IS NOT NULL

DROP TABLE BackupHistory

GO

CREATE TABLE BackupHistory

(

	DatabaseName		NVARCHAR(128),--數據庫名

	CreateDate			DATETIME,--創建時間

	Compatibilitylevel	TINYINT,--數據庫兼容級別

	RecoveryModel		CHAR(10),--恢復模式

	BackupStartData		DATETIME, --備份開始時間

	BackupEndData		DATETIME, --備份結束時間

	BackupSpace			NVARCHAR(128), --備份文件大小

	Operator			NVARCHAR(128),--執行操作者

	Servername			NVARCHAR(128),	--服務器名稱

	[FILENAME]			NVARCHAR(256) --備份文件名

);
  

建了表之后,在msdb或者AuditDB中創建這個存儲過程。一般不要在客戶數據中創建。


    /*

注意:由于用GUI備份會導致備份鏈中斷,而作業無法實現“僅復制備份”,所以使用腳本備份

create by huangzj 20120510

EXEC Backup_By_DBA 'auditdb','e:\新建文件夾\'

*/



ALTER PROC Backup_By_DBA

(

@dbname NVARCHAR(128),

@bakpath NVARCHAR(128)='E:\'

)

AS

--不備份系統表

IF @dbname IN ( 'master', 'msdb', 'model', 'tempdb' ) 

    BEGIN

        RETURN

    END 

ELSE 

    BEGIN

--定義備份時間,精確到秒

        DECLARE @date NVARCHAR(64)

        SELECT  @date = SUBSTRING(CONVERT(VARCHAR(20), GETDATE(), 121), 1, 4)

                + '_' + SUBSTRING(CONVERT(VARCHAR(20), GETDATE(), 121), 6, 2)

                + '_' + SUBSTRING(CONVERT(VARCHAR(20), GETDATE(), 121), 9, 2)

                + '_' + CONVERT(CHAR(2), DATEPART(hh, GETDATE()))

                + CONVERT(CHAR(2), DATEPART(mi, GETDATE()))

                + CONVERT(CHAR(2), DATEPART(ss, GETDATE()))

--定義要備份的數據庫名

        DECLARE @db NVARCHAR(20)

        SET @db = '' + '' + 
    
      @dbname + '' + ''
    
    

--定義備份文件的全名

        DECLARE @bakname NVARCHAR(128)

        SELECT  @bakname = @db + '_' + @date

--定義備份存放路徑

        DECLARE @disk NVARCHAR(256)

        SELECT  @disk = @bakpath + @bakname + '.bak'

--定義備份描述

        DECLARE @name NVARCHAR(128)

        SELECT  @name = @db + '-完整 數據庫 備份'

--定義錯誤信息

        DECLARE @error NVARCHAR(128)

        SELECT  @error = '驗證失敗。找不到數據庫“' + @db + '”的備份信息。'



        BACKUP DATABASE @db TO  DISK = @disk WITH  COPY_ONLY, NOFORMAT, NOINIT,  

NAME =@name, SKIP, NOREWIND, NOUNLOAD,  STATS = 10, CHECKSUM ;

        DECLARE @backupSetId AS INT

        SELECT  @backupSetId = position

        FROM    msdb..backupset

        WHERE   database_name = @db

                AND backup_set_id = ( SELECT    MAX(backup_set_id)

                                      FROM      msdb..backupset

                                      WHERE     database_name = @db

                                    )

        IF @backupSetId IS NULL 

            BEGIN

                RAISERROR(@error, 16, 1)

            END

        RESTORE VERIFYONLY FROM  DISK = @disk WITH  FILE = @backupSetId,  NOUNLOAD,  NOREWIND

        

        INSERT INTO AuditDB.dbo.BackupHistory(DatabaseName,CreateDate,Compatibilitylevel,RecoveryModel,BackupStartData,BackupEndData,BackupSpace,Operator,Servername,[FILENAME])

        SELECT a.[name] ,create_date,a.[compatibility_level] ,recovery_model_desc,S.backup_start_date,S.backup_finish_date,CONVERT(VARCHAR(20),CONVERT(DECIMAL(10,2),S.compressed_backup_size/(1024*1024)))+'MB',

        S.[user_name],S.[server_name],physical_device_name

        FROM sys.databases a INNER JOIN msdb.dbo.backupset S ON a.name=S.database_name Inner Join

            msdb.dbo.backupmediafamily M ON S.media_set_id =M.media_set_id

        WHERE a.name=db_name() AND physical_device_name=@disk

    END
  
?備注:此處只是完整備份的例子,如果需要別的備份,那么要修改腳本。

  

備份數據庫存儲過程


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美日韩免费在线视频 | 免费a级在线观看完整片 | 日本精品一区二区三区在线 | 香蕉爱爱网 | 国产精品露脸张开双腿 | 日本黄色录像 | 国产日韩高清一区二区三区 | 日韩成人免费 | 亚洲天天干 | 精品国产福利在线观看一区 | 国产一级一级一级成人毛片 | 天天视频黄 | 欧美一区二区三区视视频 | 久久毛片网站 | 国产成人精品曰本亚洲78 | 精品久久久中文字幕二区 | 国产精品免费在线播放 | www色网站| 日本在线色 | 亚洲成人aaa | 久久久久久网址 | 久久这里只有精品9 | 波多野结衣精品一区二区三区 | 老太做爰xxxx视频 | 国产精品激情综合久久 | 欧美毛片| h片免费网站 | 国产永久| 日韩精品一区二区三区毛片 | 久久国产三级精品 | 2020久久精品国产免费 | 四虎视频国产在线观看 | 在线观看三级拍拍视频 | 免费a级毛片出奶水 | 美女日日日 | 国产一级二级三级 | 久久久久久久久影院 | 欧美日韩视频在线 | 91成人午夜性a一级毛片 | 91精品成人免费国产 | 久久手机免费视频 |