Dav*_*ton 8 sql-server sql-server-express sql-server-2008
我明天正在升级客户端Access应用程序的后端,需要准备好针对此客户端的特定问题的计划.老板需要能够定期(通常是每月)将数据文件从SQL Server的办公室带走,并对数据进行统计分析.
我已经研究了将整个SQL Server数据库从服务器复制到本地SQL Express的最简单方法,并且这种解决方案在这种情况下不起作用,因为:
不能使用一次性解决方案(数据库发布向导),因为这需要是可编写脚本的.
不能使用依赖于联网的两台计算机的任何方法,因为这不是一个选项 - 数据必须通过USB拇指驱动器传输(因此,没有复制).
不能使用任何依赖于从服务器控制台或工作站运行SQL Server管理工具进行备份的方法.
无法直接连接到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)
资源:
| 归档时间: |
|
| 查看次数: |
26123 次 |
| 最近记录: |