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 / 问题 / 547005
Accepted
Sam
Sam
Asked: 2013-10-19 06:34:13 +0800 CST2013-10-19 06:34:13 +0800 CST 2013-10-19 06:34:13 +0800 CST

如何在同一台服务器上复制sql server数据库

  • 772

我有一个 SQL Server 2008 并且想要制作一个数据库的副本,所以我有一个数据库的第二个版本,用于在同一台服务器上进行测试。

数据库复制向导无法复制数据库,它总是发送有关丢失对象的有趣错误消息(使用 SMO 复制)。

当我尝试进行备份并以不同的数据库名称恢复它时,它仍然保留原始数据库的文件名并覆盖它(使原始数据库崩溃)。

那么如何复制 SQL 数据库呢?关闭 SQL Server,复制物理文件并附加它们?也许是用于数据库复制的命令行工具?不应该有一种简单的方法来制作副本吗?

sql-server
  • 2 2 个回答
  • 7871 Views

2 个回答

  • Voted
  1. Best Answer
    user113230
    2013-10-19T07:27:18+08:002013-10-19T07:27:18+08:00

    首先,您需要通过执行 sp_helpdb 'DBNAME' 并查看 [Name] 列来确定数据库文件的逻辑名称。您需要识别数据和日志文件。接下来,您需要执行完整的 copy_only 数据库备份。仅复制选项不是绝对必要的,但它可以防止原始数据库上的日志链被破坏。接下来,您需要使用 MOVE 选项执行数据库恢复,为实际的物理文件赋予新名称,这样它们就不会与您的原始数据库冲突。

    这是一个将 [Scratch] 数据库复制到 [Scratch_New] 数据库的示例。您将需要根据您的 SQL 安装调整实际的备份和数据路径。

    sp_helpdb 'Scratch'
    
    -- From the resultset of this procedure I learned that the logical 
    -- data file name is 'Scratch' and the logical log file name is 'Scratch_log'.
    
    BACKUP DATABASE [Scratch] 
    TO DISK='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\Scratch_Full_Copy.bak' WITH COPY_ONLY 
    
    RESTORE DATABASE [Scratch_New] 
    FROM DISK='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\Scratch_Full_Copy.bak'
      WITH MOVE 'Scratch' TO 'C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Data\ScratchNew.mdf',
           MOVE 'Scratch_log' TO 'C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Data\ScratchNew_Log.ldf'; 
    
    • 4
  2. knunez
    2017-03-09T06:17:41+08:002017-03-09T06:17:41+08:00

    我使用 SSMS 克隆数据库。

    1. 创建要复制的数据库的备份,并将其命名为例如 OriginalDB
    2. 右键单击 OriginalDB,选择task,然后选择Restore DB。
    3. 在选项Destination for restore中,输入数据库的新名称(例如 NewDB),然后在选项中Source for restore选择 OriginalDB。

    这将创建一个 NewDB,它是 OriginalDB 的精确副本。

    • 0

相关问题

  • sql server 连接字符串上的网络数据包大小以提高吞吐量

  • 基于 Microsoft 的服务器(IIS、MSSQL 等)上的病毒扫描应排除哪些内容?

  • SQL 洗衣清单

  • OPENROWSET、二进制文件、varchars 和 varbinaries

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

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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