将SQL Server Express数据库复制到另一台计算机

Dav*_*ton 8 sql-server sql-server-express sql-server-2008

我明天正在升级客户端Access应用程序的后端,需要准备好针对此客户端的特定问题的计划.老板需要能够定期(通常是每月)将数据文件从SQL Server的办公室带走,并对数据进行统计分析.

我已经研究了将整个SQL Server数据库从服务器复制到本地SQL Express的最简单方法,并且这种解决方案在这种情况下不起作用,因为:

  1. 不能使用一次性解决方案(数据库发布向导),因为这需要是可编写脚本的.

  2. 不能使用依赖于联网的两台计算机的任何方法,因为这不是一个选项 - 数据必须通过USB拇指驱动器传输(因此,没有复制).

  3. 不能使用任何依赖于从服务器控制台或工作站运行SQL Server管理工具进行备份的方法.

  4. 无法直接连接到SQL Server数据库进行分析,因为数据必须可移植到其他位置.

我认为我需要的是调用创建备份文件的脚本,然后将结果复制到USB驱动器的某种方法.然后我需要第二个脚本从USB驱动器复制备份文件并将其还原到另一个SQL Server.

传输的数据是只读的(或者,所做的任何更改都不需要返回主服务器),并且不会在第二个位置更新数据.它目前使用普通的旧批处理文件编写脚本来复制后端MDB文件,我需要一些对用户来说简单的东西.

它不能依赖于Powershell(SQL Server Management Studio),因为我不希望它必须安装在用户运行脚本的计算机上(有六个工作站,脚本需要可以运行,我不想在所有这些上安装一些东西).

我将设置备份代理以每晚创建备份,因此我可以复制该文件,而无需在复制之前启动备份.因此,我可能只需要在目标计算机上编写恢复脚本.

思想,建议,指针?

mar*_*c_s 13

你绝对应该能够创造类似的东西.

一部分是CREATE BACKUP作为.sql脚本的T-SQL 脚本,并使用命令行工具从标准Windows batch(*.bat)或command(*.cmd)文件执行该脚本sqlcmd.

那将是这样的:

backup.sql

BACKUP DATABASE YourDatabase
TO DISK = 'Z:\Backup\YourDatabase.bak'
WITH FORMAT;
Run Code Online (Sandbox Code Playgroud)

第二部分是带有T-SQL RESTORE脚本的.sql文件,基本上从磁盘上的给定位置读取数据并将其恢复到那里的SQL Server实例.

restore.sql

RESTORE DATABASE YourDatabase
   FROM AdventureWorks2008R2Backups 
   WITH 
     MOVE 'YourDatabase_Data' TO 'C:\MSSQL\Data\YourDatabase.mdf',
     MOVE 'YourDatabase_Log' TO 'C:\MSSQL\Data\YourDatabase_Log.ldf';
GO
Run Code Online (Sandbox Code Playgroud)

当然,您需要根据自己的实际要求调整这些名称和路径 - 但这应该只是提示您如何开始这项工作.

要使用这些.sql脚本执行其中一个sqlcmd,您需要以下内容:

sqlcmd -S (name of server) -U (login) -P (password) -I (name of script file)
Run Code Online (Sandbox Code Playgroud)

例如

sqlcmd -S (local) -U someuser -P top$secret -I backup.sql
Run Code Online (Sandbox Code Playgroud)

资源: