每小时自动恢复数据库的最佳方法

aro*_*ron 6 database sql-server database-restore sql-server-2008

我有一个演示站点,任何人都可以登录并测试管理界面.

我想每小时刷新SQL 2008数据库中的所有数据并从原始数据中恢复它.

Red Gate Software有一些很棒的工具,但是它们现在超出了我的预算.

我可以简单地制作数据库数据文件的备份副本,然后使用ac#console app删除它并复制原始文件.然后我可以有一个Windows计划任务每​​小时运行.exe.

它简单而且免费......这会有用吗?

我正在使用SQL Server 2008 R2 Web版

我知道Red Gate Software在技术上更好,因为我可以设置它来分析数据库,只更新已更改的记录,我上面的方法就像一个"大锤".

SQL*_*ace 10

它简单而且免费......这会有用吗?

是的,您可以这样做,只需记住在恢复数据库之前将数据库置于单用户模式,否则您的恢复将失败

示例脚本

USE master
GO

ALTER DATABASE YourDB SET SINGLE_USER WITH ROLLBACK IMMEDIATE
GO



RESTORE DATABASE YourDB FROM DISK=N'D:\Backup\Pristine.BAK' WITH  FILE = 1,  
NOUNLOAD,  REPLACE,  STATS = 10
GO

ALTER DATABASE YourDB SET MULTI_USER
GO
Run Code Online (Sandbox Code Playgroud)