alimack Asked: 2009-07-23 05:28:19 +0800 CST2009-07-23 05:28:19 +0800 CST 2009-07-23 05:28:19 +0800 CST 在 SQL Server 2005 中移动日志文件的最佳方法 772 显然,您可以使用 sp_attach 和 sp_detach 分离整个数据库并重新附加。有没有在线方法可以做到这一点,已经快速谷歌但看不到任何东西。 sql-server-2005 log-files 4 个回答 Voted K. Brian Kelley 2009-07-25T05:11:36+08:002009-07-25T05:11:36+08:00 需要一些停机时间的最佳方法是使用 ALTER DATABASE ... SET OFFLINE。这有几个很好的理由。 数据库所有者未更改。这可能对隐含权限和跨数据库所有权链接产生影响。 FILESTREAM(2008 年)或数据库特定配置(如跨数据库所有权链接)等配置不会丢失。 未使用错误名称重新附加数据库。脂肪指法仍然发生。 更多在这里: 如何在同一实例中移动 SQL Server 数据库而不丢失设置 gbn 2009-07-23T10:35:57+08:002009-07-23T10:35:57+08:00 抱歉,没有“安全”的在线方法。 您必须使数据库脱机或分离它。 您不能像清空数据文件那样“清空”日志文件。 微软知识库 224071 palehorse 2009-07-23T05:37:08+08:002009-07-23T05:37:08+08:00 你可以做一个备份,然后恢复备份。在还原期间,您可以为事务日志指定不同的位置。 Best Answer user13734 2009-07-23T07:04:10+08:002009-07-23T07:04:10+08:00 如果您想移动日志文件而不必使数据库脱机,那么我以前使用过一种方法。我只希望我没记错: 在新位置添加一个新的日志文件,例如: ALTER DATABASE foo ADD LOG FILE (NAME=NewLog, FILENAME='YourNewPhysicalPath', SIZE=100MB, other options ...); 清空旧的日志文件: 使用 foo; DBCC SHRINKFILE(OldLog, EMPTYFILE); 使用 BACKUP LOG foo 进行日志备份... 删除旧的日志文件: ALTER DATABASE foo 删除文件 OldLog; 如果最后一个说由于文件不为空而无法删除,请尝试再次执行 2 和 3,然后再执行 4。 编辑:好吧,事实证明我没有正确地记住它......它不会以这种方式工作,正如 gbn 指出的那样,你不能通过 SHRINKFILE“清空”日志文件(但这不是我的目标 - 我只是想要将文件标记为“不使用”,这样它就不会被重复使用,以后可以删除)。我认为对于除了第一个日志文件之外的任何其他日志文件,仍然可以使用类似的技术,但是当我有机会研究它时,我会发布它。
需要一些停机时间的最佳方法是使用 ALTER DATABASE ... SET OFFLINE。这有几个很好的理由。
更多在这里:
如何在同一实例中移动 SQL Server 数据库而不丢失设置
抱歉,没有“安全”的在线方法。
您必须使数据库脱机或分离它。
您不能像清空数据文件那样“清空”日志文件。
微软知识库 224071
你可以做一个备份,然后恢复备份。在还原期间,您可以为事务日志指定不同的位置。
如果您想移动日志文件而不必使数据库脱机,那么我以前使用过一种方法。我只希望我没记错:
在新位置添加一个新的日志文件,例如:
ALTER DATABASE foo ADD LOG FILE (NAME=NewLog, FILENAME='YourNewPhysicalPath', SIZE=100MB, other options ...);
清空旧的日志文件:
使用 foo; DBCC SHRINKFILE(OldLog, EMPTYFILE);
使用 BACKUP LOG foo 进行日志备份...
删除旧的日志文件:
ALTER DATABASE foo 删除文件 OldLog;
如果最后一个说由于文件不为空而无法删除,请尝试再次执行 2 和 3,然后再执行 4。
编辑:好吧,事实证明我没有正确地记住它......它不会以这种方式工作,正如 gbn 指出的那样,你不能通过 SHRINKFILE“清空”日志文件(但这不是我的目标 - 我只是想要将文件标记为“不使用”,这样它就不会被重复使用,以后可以删除)。我认为对于除了第一个日志文件之外的任何其他日志文件,仍然可以使用类似的技术,但是当我有机会研究它时,我会发布它。