sqlserver迁移日志文件和数据文件

sqlserver安装后没有指定日志存储路径或者还原库指定的日志存储位置不理想想要更改,都可以按照这种方式来更换;

1.前提准备:数据库的备份bak文件

2.查看自己当前数据库的日志文件和数据文件存储路径是否理想

选中当前数据库,右键属性-文件(这是我已经更改好了的位置,正常应该是位于C盘目录下)

3.找到自己的备份bak文件路径,执行查询命令

复制代码
RESTORE FILELISTONLY
FROM DISK = 'D:\yunshu\databak\WithinHospReview_backup_2025_07_14_150853_7181956.bak'

输出如下:

4:执行数据替换和迁移命令;(该命令是执行数据库还原命令,同时把这个备份库中的日志文件和数据文件迁移到我们的目标路径文件)

复制代码
RESTORE DATABASE WithinHospReview
FROM DISK = 'D:\yunshu\databak\WithinHospReview_backup_2025_07_14_141827_2041194.bak'
WITH MOVE 'WithinHospReview' TO 'D:\yunshu\SQLData\WithinHospReview.mdf',
     MOVE 'WithinHospReview_log' TO 'D:\yunshu\SQLLogs\WithinHospReview_log.ldf',
     REPLACE;

WithinHospReview是我的数据库名字,D:\yunshu\databak\WithinHospReview_backup_2025_07_14_141827_2041194.bak是我都数据库备份bak文件路径;WithinHospReview_log和WithinHospReview名字就是对应我执行步骤三所查询出来的名字,一定要对应哦,D:\yunshu\SQLData\WithinHospReview.mdf和'D:\yunshu\SQLLogs\WithinHospReview_log.ldf'就是我要的目标路径了,新的日志文件和数据会存储到这个新文件中;

附:

如果当前数据库在使用中,执行步骤4会报错:

复制代码
执行时报错:消息 3102,级别 16,状态 1,第 10 行
RESTORE 无法处理数据库 'WithinHospReview',因为它正由此会话使用。建议在执行此操作时使用 master 数据库。
消息 3013,级别 16,状态 1,第 10 行
RESTORE DATABASE 正在异常终止。

可以依次执行

复制代码
//切换到master数据库
USE master;

//把目标数据库切换到单用户模式,强制断开其他连接
ALTER DATABASE WithinHospReview SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
//执行还原语句
RESTORE DATABASE WithinHospReview
FROM DISK = 'D:\yunshu\databak\WithinHospReview_backup_2025_07_14_141827_2041194.bak'
WITH MOVE 'WithinHospReview' TO 'D:\yunshu\SQLData\WithinHospReview.mdf',
     MOVE 'WithinHospReview_log' TO 'D:\yunshu\SQLLogs\WithinHospReview_log.ldf',
     REPLACE;
//还原完成后,切换回多用户模式
 ALTER DATABASE WithinHospReview SET MULTI_USER;

5.检查还原后的日志文件和数据文件位置

相关推荐
Navicat中国39 分钟前
如何使用 Ollama 配置 AI 助手 | Navicat 教程
数据库·人工智能·ai·navicat·ollama
小猿姐5 小时前
实测对比:哪款开源 Kubernetes MySQL Operator 最值得用?(2026 深度评测)
数据库·mysql·云原生
倔强的石头_7 小时前
从 “存得下” 到 “算得快”:工业物联网需要新一代时序数据平台
数据库
TDengine (老段)8 小时前
TDengine IDMP 可视化 —— 分享
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据·时序数据
GottdesKrieges9 小时前
OceanBase数据库备份配置
数据库·oceanbase
SPC的存折9 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_9 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
炸炸鱼.11 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
softshow102611 小时前
Etsy 把 1000 个 MySQL 分片迁进 Vitess
数据库·mysql
Ronaldinho Gaúch11 小时前
MySQL基础
数据库·mysql