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.检查还原后的日志文件和数据文件位置

相关推荐
givemeacar2 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
skiy2 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
IvorySQL2 小时前
PostgreSQL 技术日报 (3月24日)|当 MVCC 成本被重新审视
数据库·postgresql·开源
2401_895521342 小时前
PostgreSQL_安装部署
数据库·postgresql
Hvitur2 小时前
软考架构师【第六章】数据库设计基础知识
数据库·oracle
养生技术人2 小时前
Oracle OCP认证考试题目详解082系列第5题
运维·数据库·sql·oracle·开闭原则
2401_879693872 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
yunyun321232 小时前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
IvorySQL2 小时前
明晚开播|PostgreSQL 18.3 x IvorySQL 5.3:开启 AI 数据库新纪元
数据库·postgresql·开源
Sunshine for you4 小时前
如何用FastAPI构建高性能的现代API
jvm·数据库·python