How to backup log after MDB file broken.

复制代码
CREATE DATABASE BackupDemo
GO
USE BackupDemo
GO
CREATE TABLE dbo.T1
(
    LogDesc NVARCHAR(200),
    LogTime DATETIME DEFAULT GETDATE()
)
GO
INSERT INTO dbo.T1(LogDesc)
SELECT 'Before full backup'
GO
BACKUP DATABASE [BackupDemo] TO  DISK = N'I:\Backup\BackupDemo_Full.bak' 
WITH NOFORMAT, NOINIT,  NAME = N'BackupDemo-Full Database Backup', SKIP, NOREWIND, NOUNLOAD,  STATS = 10
GO
INSERT INTO dbo.T1(LogDesc)
SELECT 'after full backup'
GO
--Stop SQL SERVER AND Delete the mdb file and restart SQL SERVER
GO
--备份为日志,一定要使用NO_TRUNCATE,否则无法备份
BACKUP LOG [BackupDemo] TO  DISK = N'I:\Backup\BackupDemo_LOG.bak' 
WITH NOFORMAT, NOINIT,NO_TRUNCATE
GO
--恢复数据库
RESTORE DATABASE [BackupDemo] FROM  DISK = N'I:\Backup\BackupDemo_Full.bak' WITH  FILE = 1,  NORECOVERY,  NOUNLOAD,  STATS = 10
GO
RESTORE LOG [BackupDemo] FROM  DISK = N'I:\Backup\BackupDemo_LOG.bak' WITH  FILE = 1,  NOUNLOAD,  STATS = 10
GO
--检查数据库
USE BackupDemo
GO
SELECT * from dbo.T1
复制代码

 

在实例和数据库发生崩溃时:

1.将数据库相关文件复制保存,以防止后续错误修改损坏文件;

2.在新服务器上创建同名数据库(确保文件名与原文件名相同),关闭服务器,删除数据文件(MDF),将原有LDF文件覆盖新创建的日志文件,重启服务器

3.使用NO_TRUNCATE来备份尾日志文件。

4.使用原有备份文件和尾日志文件还原数据库。

 

posted on   笑东风  阅读(338)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现

导航

点击右上角即可分享
微信分享提示