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 / 问题 / 44014
Accepted
alimack
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 4 个回答
  • 4044 Views

4 个回答

  • Voted
  1. K. Brian Kelley
    2009-07-25T05:11:36+08:002009-07-25T05:11:36+08:00

    需要一些停机时间的最佳方法是使用 ALTER DATABASE ... SET OFFLINE。这有几个很好的理由。

    1. 数据库所有者未更改。这可能对隐含权限和跨数据库所有权链接产生影响。
    2. FILESTREAM(2008 年)或数据库特定配置(如跨数据库所有权链接)等配置不会丢失。
    3. 未使用错误名称重新附加数据库。脂肪指法仍然发生。

    更多在这里:

    如何在同一实例中移动 SQL Server 数据库而不丢失设置

    • 4
  2. gbn
    2009-07-23T10:35:57+08:002009-07-23T10:35:57+08:00

    抱歉,没有“安全”的在线方法。

    您必须使数据库脱机或分离它。

    您不能像清空数据文件那样“清空”日志文件。

    微软知识库 224071

    • 2
  3. palehorse
    2009-07-23T05:37:08+08:002009-07-23T05:37:08+08:00

    你可以做一个备份,然后恢复备份。在还原期间,您可以为事务日志指定不同的位置。

    • 1
  4. Best Answer
    user13734
    2009-07-23T07:04:10+08:002009-07-23T07:04:10+08:00

    如果您想移动日志文件而不必使数据库脱机,那么我以前使用过一种方法。我只希望我没记错:

    1. 在新位置添加一个新的日志文件,例如:

      ALTER DATABASE foo ADD LOG FILE (NAME=NewLog, FILENAME='YourNewPhysicalPath', SIZE=100MB, other options ...);

    2. 清空旧的日志文件:

      使用 foo; DBCC SHRINKFILE(OldLog, EMPTYFILE);

    3. 使用 BACKUP LOG foo 进行日志备份...

    4. 删除旧的日志文件:

      ALTER DATABASE foo 删除文件 OldLog;

    如果最后一个说由于文件不为空而无法删除,请尝试再次执行 2 和 3,然后再执行 4。

    编辑:好吧,事实证明我没有正确地记住它......它不会以这种方式工作,正如 gbn 指出的那样,你不能通过 SHRINKFILE“清空”日志文件(但这不是我的目标 - 我只是想要将文件标记为“不使用”,这样它就不会被重复使用,以后可以删除)。我认为对于除了第一个日志文件之外的任何其他日志文件,仍然可以使用类似的技术,但是当我有机会研究它时,我会发布它。

    • 0

相关问题

  • MS SQL 2005 升级问题 - 看起来 msdb 没有升级 - 如何修复?

  • 加快 MSSQL 快照复制到 SQLExpress 副本的速度

  • 如何提高 SQL Server 镜像性能

  • 聚集索引与非聚集索引?

  • 安全地授予对 SQL 2005 复制监视器的访问权限以创建快照

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