当前位置:首页 > 技术 > 正文内容

SQL Server数据库备份文件还原操作指南

访客 技术 2026年6月11日 1

在实际工作中,我们经常需要将某个服务器上的数据库备份文件还原到本地计算机进行测试或开发。本文详细介绍从A服务器备份的数据库文件还原到本地B电脑的操作步骤。

操作环境说明

本次演示的数据库版本相同,因此未涉及版本兼容性问题。操作前请确认源数据库和目标数据库的版本一致。

还原前准备工作

第一步:准备备份文件

确保已获取有效的.bak备份文件,并记住文件的存放路径。

第二步:创建目标数据库

在目标SQL Server实例中新建一个空白数据库,作为还原的目标数据库。建议数据库名称与备份文件对应,例如命名为LocalDB。

第三步:设置数据库访问模式(可选)

为确保还原过程顺利进行,可将目标数据库设置为单用户模式,避免其他连接干扰还原操作。还原完成后记得切换回多用户模式。

第四步:配置身份验证方式

建议使用Windows身份验证方式连接数据库,以获得足够的系统权限。

第五步:配置文件夹权限

需要为SQL Server数据文件夹配置适当的访问权限。将数据文件和日志文件的目录添加Everyone用户组的读取和写入权限,防止因权限不足导致还原失败。

执行数据库还原

完成上述准备工作后,使用以下T-SQL语句执行还原操作:

USE master

RESTORE DATABASE LocalDB 
FROM DISK = 'D:\Backup\Database_202106151450.bak' 
WITH FILE = 1,
MOVE N'OriginalDB' TO N'C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\LocalDB.mdf',
MOVE N'OriginalDB_Log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\LocalDB_log.ldf',
NOUNLOAD, 
REPLACE, 
STATS = 10

关键参数说明:

  • RESTORE DATABASE LocalDB:指定要还原的目标数据库名称
  • FROM DISK:指定备份文件的完整路径
  • MOVE:将备份中的原始数据文件和日志文件重新映射到新的目标路径
  • REPLACE:如果目标数据库已存在,则覆盖现有数据库
  • STATS = 10:每还原10%的数据时显示进度信息

执行成功后,系统会显示还原进度百分比,当显示100%时表示还原完成。

常见还原错误及解决方案

错误场景一:权限不足导致还原失败

如果遇到以下错误信息:

消息 3634,级别 16,状态 1,第 17 行
The operating system returned the error '5(拒绝访问。)' while attempting 'RestoreContainer::ValidateTargetForCreation' on 'C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\LocalDB.mdf'.

消息 3156,级别 16,状态 5,第 17 行
File 'OriginalDB' cannot be restored to 'C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\LocalDB.mdf'. Use WITH MOVE to identify a valid location for the file.

消息 3013,级别 16,状态 1,第 17 行
RESTORE DATABASE is terminating abnormally.

原因分析:

这是由于目标文件夹的访问权限不足导致。SQL Server服务账户没有足够的权限在指定目录创建文件。

解决方案:

方案一:修改目标文件夹权限,为SQL Server服务账户或Users组添加完全控制权限。

方案二(推荐):将数据文件和日志文件还原到其他磁盘分区。具体步骤如下:

  1. 将目标数据库进行分离操作
  2. 将数据文件和日志文件移动到具有足够权限的目录
  3. 重新执行还原命令,修改MOVE参数指向新路径

方案三:更改SQL Server服务的启动账户为具有管理员权限的账户。

注意事项

  • 还原前务必确认备份文件的完整性
  • 确保目标数据库没有正在进行的连接
  • 还原操作最好在业务低峰期进行
  • 还原完成后记得将数据库切换回多用户模式
  • 建议在还原前备份现有的数据库(如果存在)

通过以上步骤和解决方案,通常可以顺利完成SQL Server数据库的还原操作。如果遇到其他问题,建议检查SQL Server错误日志获取更详细的错误信息。

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

linux screen 用法详情 (nohup 的替代方案)

一、screen 是什么?能干嘛?screen 是一个终端复用器,可以:在一个 SSH 会话中开多个“虚拟终端”SSH 断线后,程序仍然在后台运行随时重新连接到原来的会话特别适合:nohup 的替代方案跑脚本 / 爬虫 / 训练模型运维、远程开发二、安装 screen# CentOS / Rocky / Almayum install -y screen# Debian / Ubuntuapt i...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。