查异常数据
use 数据库名
dbcc checkdb
手工修复数据库,不用改单用户模式—更新页
dbcc updateusage('数据库名','架构名')
更改成单用户
alter database 数据库名 set single_user with rollback immediate
还原成多用户模式
alter database 数据库名 set multi_user with rollback immediate
数据修复—需改为单用户
1、快速修复
DBCC CHECKDB ('数据库名', REPAIR_FAST)
2、重建索引并修复
DBCC CHECKDB ('数据库名', REPAIR_REBUILD)
3、如果必要允许丢失数据修复
DBCC CHECKDB ('数据库名'', REPAIR_ALLOW_DATA_LOSS)
–以repair_allow_data_loss级别修复表
dbcc checktable('Tb_Archives_File_1',repair_allow_data_loss)
go
–若还有问题,修复索引表
DBCC DBREINDEX('Tb_Archives_File_1')
–再修复表
DBCC CHECKTABLE('Tb_Archives_File_1')
–查询是否正常
select * from Tb_Archives_File_1
附加mdf报错,错误:1813
新建相同的数据库名称,停止sql,覆盖mdf
alter database 数据库名 set emergency --设置紧急状态
alter database 数据库名 set single_user --设置单用户模式
dbcc checkdb('数据库名',REPAIR_ALLOW_DATA_LOSS) --检查并重建日志,时间比较久
dbcc checkdb('数据库名',REPAIR_REBUILD) --上句报错执行此语句,无报错跳过
Sp_dboption '数据库名', 'single user', 'false' --恢复成多用户模式