AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 49944
In Process
Geo
Geo
Asked: 2009-08-05 10:29:00 +0800 CST2009-08-05 10:29:00 +0800 CST 2009-08-05 10:29:00 +0800 CST

如何为 MSSQL 引擎上的每个数据库编写备份脚本?

  • 772

我们需要在一个 MS SQL Server 引擎中备份 40 个数据库。我们使用以下脚本备份每个数据库:

BACKUP DATABASE [dbname1] TO  DISK = N'J:\SQLBACKUPS\dbname1.bak' WITH NOFORMAT, INIT,  NAME = N'dbname1-Full Database Backup', SKIP, NOREWIND, NOUNLOAD,  STATS = 10
GO
declare @backupSetId as int
select @backupSetId = position from msdb..backupset where database_name=N'dbname1' and backup_set_id=(select max(backup_set_id) from msdb..backupset where database_name=N'dbname1' )
if @backupSetId is null begin raiserror(N'Verify failed. Backup information for database ''dbname1'' not found.', 16, 1) end
RESTORE VERIFYONLY FROM  DISK = N'J:\SQLBACKUPS\dbname1.bak' WITH  FILE = @backupSetId,  NOUNLOAD,  NOREWIND
GO

我们希望在脚本中添加获取每个数据库并在上述脚本中替换它的功能。基本上是一个脚本,它将从引擎创建和验证每个数据库备份。

我正在寻找这样的东西:

For each database in database-list
    sp_backup(database) // this is the call to the script above.
End For

有任何想法吗?

sql-server backup windows-server-2003 database
  • 4 4 个回答
  • 2373 Views

4 个回答

  • Voted
  1. Jason Cumberland
    2010-03-23T14:00:07+08:002010-03-23T14:00:07+08:00

    您可以使用未记录的数据库循环过程来执行此操作。

    use [master]
    go
    
    set quoted_identifier off
    
    exec sp_MSforeachdb "
    if ( '?' not in ( 'master', 'msdb', 'model', 'tempdb' ) )
    begin
    
    BACKUP DATABASE [?] TO  DISK = N'J:\SQLBACKUPS\?.bak' WITH NOFORMAT, INIT,  NAME = N'?-Full Database Backup', SKIP, NOREWIND, NOUNLOAD,  STATS = 10
    
    declare @backupSetId as int
    
    select @backupSetId = position from msdb..backupset where database_name=N'?' and backup_set_id=(select max(backup_set_id) from msdb..backupset where database_name=N'?' )
    
    if ( @backupSetId is null )
    begin
        raiserror(N'Verify failed. Backup information for database ''?'' not found.', 16, 1)
    end
    
    RESTORE VERIFYONLY FROM  DISK = N'J:\SQLBACKUPS\?.bak' WITH  FILE = @backupSetId,  NOUNLOAD,  NOREWIND
    
    end
    "
    
    • 2
  2. David Spillett
    2009-08-05T11:54:56+08:002009-08-05T11:54:56+08:00

    就像是:

    1. 为 `SELECT name FROM master..sysdatabases WHERE name NOT IN ('list','of','dbs','to','skip') 创建一个游标
    2. 遍历它并在每个循环上:
      1. 将您的脚本构建为临时 SQL 字符串
      2. (让上述临时 SQL 将任何结果记录在某处的小型日志数据库中)
      3. 使用 EXEC (@sql) 运行它
    3. 根据存储的结果输出一个简单的报告以进行完整性检查

    应该做的伎俩。

    市场上还有许多产品为 SQL Server 提供了非常灵活的备份选项,如果您的脚本变得更复杂,这可能更适合生产使用(尽管它们无疑并不便宜)。

    • 1
  3. Hondalex
    2009-08-05T12:03:49+08:002009-08-05T12:03:49+08:00

    我知道这不是对您的问题的直接回应,因为您想要一些带有特定脚本的东西,但我想我把它扔在那里。

    如果您有完整版的 MS SQL,而不是 MS SQL Express,则可以执行维护计划路线。这是来自 Sunbelt Software 的 PDF,它提供了一个很好的使用方法,您可以在此处选择要备份的数据库:SQL-2005-maintenance-plan.pdf

    • 1
  4. djangofan
    2010-03-31T12:10:32+08:002010-03-31T12:10:32+08:00

    我会改进你的脚本:

    :: copyonlybackup.bat
    IF EXIST "%1_COPYONLY.BAK" (
      sqlcmd -U sa -P xxxxxxx -S SQL-DB -Q "BACKUP DATABASE %1 TO DISK = '%1_COPYONLY.BAK' WITH COPY_ONLY,INIT;"
    echo Overwriting previous COPY_ONLY backup of %1 .
    ) ELSE (
      sqlcmd -U sa -P xxxxxxx -S SQL-DB -Q "BACKUP DATABASE %1 TO DISK = '%1_COPYONLY.BAK' WITH COPY_ONLY;"
      echo Creating new COPY_ONLY backup of %1 .
    )
    

    然后用

    :: RUNSCRIPTS.bat
    F:
    CD "F:\Microsoft SQL Server\MSSQL.1\MSSQL\Backup"
    
    @REM  Doing simple copies just in case
    call COPYONLYBACKUP.bat db1
    call COPYONLYBACKUP.bat db2
    call COPYONLYBACKUP.bat db3
    ...
    

    最后,如果您需要一个循环,请在上面显示的 RUNSCRIPTS.bat 文件中使用类似这样的内容:

    for /f %%a IN (myfile.txt) do call copyonlybackup.bat %%a
    

    要生成 myfile.txt,您可能可以让 SQL 以某种方式生成它:

    EXEC sp_msForEachDB 'PRINT ''?'''
    
    • 0

相关问题

  • 在 Windows Server 2003 下使用 wscipt 从 .asp 文件运行 .exe

  • 最佳混合环境(OS X + Windows)备份?[关闭]

  • 在 SQL Server 中,何时应将 PRIMARY Data FileGroup 拆分为辅助数据文件?

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve