• 备份SQL Server数据库


    网站搬迁之后,备份数据库的功能出错了,原因是原来数据库与网站同一台服务器,现在是数据库与网站分别在不同服务器,引起在备分时,找不到路径或是没有权限存储。

    最初版本的存储过程:

    代码
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO

    ALTER PROCEDURE [dbo].[usp_Backup_DataBase]
    (
    @BackupDataBaseName varchar(128),
    @FileName nvarchar(1000)
    )
    AS
    BACKUP DATABASE @BackupDataBaseName TO DISK = @FileName
    IF @@ERROR <>0
    BEGIN
        
    RAISERROR(N'数据库备份失败!',16,1)
        
    RETURN
    END

      

    更新后的存储过程:

    代码
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO

    ALTER PROCEDURE [dbo].[usp_Backup_DataBase]
    (
        
    @BackupDataBaseName varchar(128),
        
    @FileName nvarchar(128)
    )
    AS
    DECLARE @BKFULLPATH NVARCHAR(1000)

    --get SQL server Default Backup path
    --
    reference:http://www.cnblogs.com/insus/articles/1914932.html
    SELECT @BKFULLPATH = [dbo].[udf_SQLServerBackupDirectory]() + '\' + @FileName
    BACKUP DATABASE @BackupDataBaseName TO DISK = @BKFULLPATH WITH INIT


    DECLARE @MapString NVARCHAR(1000)

    /*--说明: 
    L: 是映射网络路径对应本机的盘符,与下面的备份对应 
    \\192.168.0.37\E$    是要映射的网络路径 
    192.168.0.37\administrator    
    192.168.0.37是远程的计算机名,administrator是登陆的用户名 
    password:上面指定的administrator用户的密码 
    --
    */ 

    SET @MapString = 'NET USE L: "\\192.168.0.37\E$" "password" "/USER:192.168.0.37\administrator"'
    EXECUTE master..xp_cmdshell @MapString

    --把备份文件拷贝至映射路径中
    DECLARE @CopyString NVARCHAR(1000= 'COPY "' + @BKFULLPATH + '" L:'
    EXECUTE master..xp_cmdshell @CopyString

    --删除备份文件
    DECLARE @OrgBkFileString NVARCHAR(1000= 'DEL "' + @BKFULLPATH + '"'
    EXECUTE master..xp_cmdshell @OrgBkFileString

    --删除映射路径
    EXECUTE master..xp_cmdshell 'NET USE L: /DELETE'


    IF @@ERROR <> 0
    BEGIN
        
    RAISERROR(N'数据库备份失败!',16,1)
        
    RETURN
    END
  • 相关阅读:
    编写登陆认证程序
    Ubuntu18.04安装MySQL
    python输出的高亮显示
    河北省赛
    dp
    迷宫问题
    牛客-幸运数字Ⅱ
    [管理运筹学]线性规划&单纯形法的各种姿势(题目:[NOI2008]志愿者招募)
    [管理运筹学]指派问题的匈牙利算法及其c++实现 (例:「网络流 24 题」分配问题 )
    打算在CSDN写了,虽然博客园也很好
  • 原文地址:https://www.cnblogs.com/insus/p/1916270.html
Copyright © 2020-2023  润新知