SQL Server:如何检测和修复 FILESTREAM 数据库损坏?

SQL Server 中的 FILESTREAM 功能可以将二进制大型对象 (BLOB) 存储到文件系统上,而不是将它们存储在数据库中。但是,默认情况下不启用此功能。用户需要使用 SQL Server Management Studio (SSMS) 和 SQL Server Configuration Manager 来启用它。启用此功能后,这些文件将存储在 FILESTREAM 文件组中。此时,可以使用 T-SQL 事务访问这些文件。

有时,修改或删除 FILESTREAM 文件夹中的文件或将文件保存到 SQL Server 数据库可能会导致 SQL Server 数据库不一致或损坏。如果 FILESTREAM 文件组已损坏,则数据库将进入“等待恢复”状态。本文将讨论可能导致 SQL Server FILESTREAM 数据库损坏的原因,并了解如何解决损坏和恢复数据库。

SQL Server 中启用 FILESTREAM 数据库损坏的原因

启用 FILESTREAM 的数据库可能会因各种原因而损坏。一些常见原因是:

  • FILESTREAM 将文件引用和元数据存储在数据库中。如果 SQL 数据库本身由于硬件故障、磁盘问题等原因而损坏,则将文件链接到数据库的引用也会变得不一致。
  • FILESTREAM 中的实际数据存储在文件系统上。这些数据可能会因坏扇区、磁盘故障和其他问题而损坏。
  • 如果直接删除或修改数据容器内文件系统文件夹中的文件,则可能会导致文件系统与 SQL Server 不一致,从而导致 FILESTREAM 数据损坏。

如何检测 SQL Server 中启用 FILESTREAM 的数据库的损坏?

可以使用 DBCC CHECKDB 命令检测启用了 FILESTREAM 的 SQL 数据库中的损坏或物理和逻辑一致性问题。它还可以验证表的元数据与 FILESTREAM 文件系统的文件和目录之间的链接级一致性。以下是使用 DBCC CHECKDB 命令检查启用了 filestream 的数据库中的损坏的方法:

DBCC CHECKDB 'database_name';

DBCC CHECKDB 命令可以报告错误,如 7903、7904、7905、7907 等。此类错误表示由于篡改 SQL Server FILESTREAM 文件夹而发生的损坏、不一致或完整性问题。

修复启用 FILESTREAM 的 SQL Server 数据库中损坏的方法

如果启用了 FILESTREAM 的 SQL 数据库已损坏、损坏或无法访问,可以按照以下方法操作。

方法 1:从文件组备份还原

Filestream 数据存储在 FILESTREAM 文件组中。它包含称为数据容器的文件系统目录。如果在 SQL Server 中有文件和文件组备份,则可以轻松地从备份中还原数据库。在此之前,请使用 RESTORE FILELISTONLY 命令确保备份文件包含 FILESTREAM 数据。此命令显示备份中的所有文件。

以下是从 SQL Server 备份还原数据库的步骤:

  • 打开 SSMS,然后在对象管理器中连接到 SQL Server 数据库引擎的相应实例。
  • 单击服务器名称展开服务器树。
  • 接下来,展开‘Databases’选项卡。选择一个用户数据库或展开‘System Database’。
  • 单击‘System Database’,右键单击数据库,单击任务>还原>文件和文件组。

  • 接下来,选择 'From database' 或 'From device' 选项来指定备份集的来源和位置。

  • 在“选择要恢复的备份集区域,选择要恢复的备份。该部分显示所选位置的所有可用备份。
  • 单击“恢复文件和文件组”对话框中“选择页面下方的“选项”页面以选择高级选项。
  • 在 Restore options 面板中,选择以下选项之一:
  • 还原为文件组
  • 覆盖现有数据库
  • 在还原每个备份之前提示
  • 限制对已还原数据库的访问
  • 单击 OK。

这些操作将还原数据库。可以使用以下命令找到 FILESTREAM 组的物理文件夹:

SQL
SELECT name, physical_name, state_desc, type_desc FROM sys.database_filesWHERE type_desc = 'FILESTREAM'

或者,也可以使用 Transact-SQL 命令还原文件和文件组备份。

方法 2:使用 DBCC CHECKDB 命令

如果备份已过时或不可用,则可以使用 DBCC CHECKDB 命令修复数据库带有REPAIR_ALLOW_DATA_LOSS修复选项。

  • 首先,使用以下命令将数据库设置为 SINGLE_USER 模式:

ALTER DATABASE Dbtesting SET SINGLE_USER

  • 接下来,使用 DBCC CHECKDB 命令修复数据库,如下所示:

DBCC CHECKDB (N ’Dbtesting’, REPAIR_ALLOW_DATA_LOSS) WITH ALL_ERRORMSGS, NO_INFOMSGS;

GO

  • 现在,通过执行以下命令将数据库设置为 MULTI_USER 模式

ALTER DATABASE Dbtesting SET MULTI_USER

尽管上述 DBCC CHECKDB 命令可以修复启用了 FILESTREAM 的数据库中与损坏相关的问题,但它具有某些限制。它可能会使数据库处于逻辑不一致的状态。在修复复杂错误时,需要多次使用该命令,这是一个耗时的过程。此外,它还可能在修复数据库时解除分配行或页,从而导致数据丢失。

方法 3:使用专业的 SQL 修复工具

要精确和完整地修复数据库文件,用户可以使用专门的 SQL 修复工具,以便可以快速修复 MDF 文件。使用专业的SQL数据修复工具有助于解决 DBCC CHECKDB 命令报告的 SQL 数据库中所有与损坏相关的错误。这类软件工具拥有直观的用户界面,用户可以轻松执行修复过程。

优秀的 SQL 数据修复工具拥有的主要特点:

  • 修复 MDF 和 NDF 数据库文件,而不会丢失任何数据
  • 恢复所有数据库组件,包括已删除的表、键、索引、触发器和存储过程
  • 支持 SQL Server FILESTREAM 数据类型、XML 数据类型、SQL Server 稀疏列、XML 索引和 SQL Server 列集属性
  • 使用 PAGE 和 ROW 压缩恢复 SQL 表
  • 在保存之前提供可恢复数据库对象的预览
  • 支持数据库对象的选择性恢复
  • 将修复后的数据库保存到新的或实时数据库以及 CSV、HTML 和 XLS 等格式
  • 广泛支持各种 SQL Server 数据库版本
  • 与 Windows 和 Linux 操作系统兼容

方法 4:寻求专业的数据恢复服务

专业的数据恢复服务可以快速可靠地帮助用户恢复受损的数据,同时避免数据状况进一步恶化。遇到数据危机时,第一时间寻求专业的救援,避免自行尝试,是防范人为误操作的明智选择。

总结

启用 FILESTREAM 的数据库损坏可能由于多种原因而发生。我们在上面讨论了如何在 SQL Server 中修复损坏的启用 FILESTREAM 的数据库。您可以轻松地从备份中恢复数据库。但是,如果您的备份无法访问,则可以使用 DBCC CHECKDB 命令修复数据库。但是,此方法需要您的时间和精力,并且不能保证完整的数据库恢复。因此,为了实现无缝恢复过程,请使用专业人员SQL 修复工具,例如 MS SQL 的 Stellar Repair。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/88690.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/88690.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FORCE 开发者论坛 | 火山引擎发布多款 Agent 开发工具

资料来源:火山引擎-开发者社区 6 月 12 日,2025 火山引擎 FORCE 原动力大会开发者论坛成功举办。大会聚焦 Agent 开发新范式,升级发布了 PromptPilot、MCP Servers、TRAE、扣子开发平台等产品,以及多款开源项目,构建起…

【Qt-windows】如何使用perfmon 具体分析windows serverR2的Qt程序CPU问题

可以使用 Windows 自带的 PerfMon(Performance Monitor) 工具对运行在 Windows Server R2 上的 Qt 程序进行详细的性能分析,尤其是 CPU 使用情况。以下是具体的操作步骤和建议: 一、打开 PerfMon 工具 按下 Win R 打开运行窗口。…

【软考高级系统架构论文】论NoSQL数据库技术及其应用

论文真题 随着互联网web2.0网站的兴起,传统关系数据库在应对web2.0 网站,特别是超大规模和高并发的web2.0纯动态 SNS 网站上已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。 NoSQL(Not only SQL )的产生就是为了解…

bash的配置文件,source

一.按生效范围分类 二.按shell登录的方式分类 这里的执行顺序存疑,因为会互相调用,不需要记忆 source执行脚本 source不创建子进程,bash创建子进程 普通脚本:用bash 配置文件脚本:用source 三.按功能分类

30道C语言高频题整理(附答案背诵版)

1.请描述一下C语言的基本数据类型有哪些? C语言提供了一系列的基本数据类型,它们是构建更复杂数据结构的基础。这些基本数据类型主要包括: 整型(Integer Types):用于存储整数值。根据存储大小和符号性&…

使用Tailwind CSS和i18n的react实践

首先在 src 下设置 i18n.js 文件 // src/i18n.js import i18n from i18next; import { initReactI18next } from react-i18next;import en from ./locales/en/public; import zh from ./locales/zh/public;i18n.use(initReactI18next) .init({resources: {en: { translation:…

生信自学路线|R语言的数据变量类型与对应运算

R 是一种动态类型语言,使用灵活,变量无需预先声明类型。掌握 R 的数据类型和变量机制,是后续进行数据处理和建模分析的基础。本章节主要介绍 R 语言中的常量、变量、基本数据类型及常用数据结构,并结合示例进行说明。 文章目录 一…

UI前端大数据处理优化策略:提升数据处理速度与准确性

hello宝子们...我们是艾斯视觉擅长ui设计、前端开发、数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 在数字化浪潮下,前端面临的数据规模正呈指数级增长 ——IDC 预测,2025…

技术调研:时序数据库(二)

除了 InfluxDB、TDengine 和 TimescaleDB,还有其他多个主流的开源时序数据库,各自针对不同场景优化。以下是补充的时序数据库选型清单,涵盖其核心特性、适用场景及局限性: 1. 监控与运维场景 (1) Prometheus 核心优势&#xff1…

【C++/C】十进制数转为十六进制时,如何区分正负? 负数补码高位是1,那么一个很大的正数,高位也会出现1,会和负数搞混吗?

文章目录 1 十进制数转为十六进制时,如何区分正负?1.1 正数处理1.2 负数处理‌1.3 关键点‌ 2 负数补码高位是1,那么一个很大的正数,高位也会出现1,会和负数搞混吗?2.1 符号位明确区分‌2.2 补码的数值范围…

Elasticsearch 如果保证读写一致

Elasticsearch 通过多机制组合保障读写一致性,针对高并发场景优化设计,具体实现如下: 一、写入一致性控制‌ ‌1.1 一致性级别参数(consistency)‌ 写操作时指定分片确认数量,确保数据可靠同步&am…

内嵌lua解释器 作为组件命令调试

给不同的组件传递不通的参数 好处就是调试代码 只在 lua 代码出现,同时为设备初始化 增加了外部脚本配置的功能接口

Excel工具箱WPS版 增强插件 文本处理、批量录入 数据对比 高级排序

各位Excel办公达人们,今天咱来聊聊方方格子Excel工具箱V3.6.6.0(WPS版)!这玩意儿啊,就是专门给WPS Office用户量身打造的Excel增强插件。它集成了上百项实用功能,能帮咱高效处理数据、优化表格操作&#xf…

创建AWS Bedrock知识库及填坑指南

前言 作者之前的关于Dify实践RAG系统的文章:用它搭建AI Agent原来这么简单!-CSDN博客,文末留了TODO: “后面会对此RAG系统进行扩展和增强: 1)知识库同步自Web站点 2)链接外部知识库 3&…

Swift 变量

Swift 变量 在 Swift 编程语言中,变量是存储数据的基本方式。它们用于在程序的运行过程中保存和修改数据。理解 Swift 中的变量类型和用法对于编写高效、可维护的代码至关重要。 变量的定义 变量在 Swift 中是通过关键字 var 来定义的。定义变量时,需要指定变量存储的数据…

板凳-------Mysql cookbook学习 (十--9)

8.15 基于日期的摘要 Monday, June 23, 2025 mysql> use cookbook Database changed mysql> select trav_date,-> count(*) as number of drivers, sum(miles) as miles logged-> from driver_log group by trav_date; -----------------------------------------…

redis的scan使用详解,结合spring使用详解

Redis的SCAN命令是一种非阻塞的迭代器,用于逐步遍历数据库中的键,特别适合处理大数据库。下面详细介绍其使用方法及在Spring框架中的集成方式。 SCAN命令基础 SCAN命令的基本语法: SCAN cursor [MATCH pattern] [COUNT count]cursor&#…

Go 语言并发模式实践

在 Go 语言并发编程中,合理的并发模式能显著提升程序的可维护性和性能。本文将深入解析三种典型的并发模式实现,通过具体案例展示如何优雅地管理任务生命周期、资源池和工作 goroutine 池。 一、runner 模式:任务生命周期管理 在定时任务、…

【Java 开发日记】你会不会使用 SpringBoot 整合 Flowable 快速实现工作流呢?

目录 1、流程引擎介绍 2、创建项目 3、画流程图 4、开发接口 4.1 Java 类梳理 ProcessDefinition ProcessInstance Activity Execution Task 4.2 查看流程图 4.3 开启一个流程 4.4 将请求提交给组长 4.5 组长审批 4.6 经理审批 4.7 拒绝流程 1、流程引擎介绍 …

面试150 分发糖果

思路 联想贪心算法,遍历两次数组,一次是从左到右遍历,只比较右边孩子评分比左边打的情况。第二次从右到左遍历,只比较左边孩子评分比右边大的情况。最后求和即可 class Solution:def candy(self, ratings: List[int]) -> int…