MSSQL数据库损坏的修复命令DBCC简介

来源:互联网 发布:淘宝上拍卖会是真的吗 编辑:程序博客网 时间:2024/05/19 22:56

DBCC命令能对数据库进行维护,重点介绍内容:

一、CHECKALLOC 磁盘空间一致性

二、CHECKCATALOG 系统表一致性

三、CHECKCONSTRAINTS约束完整性

四、CHECKDB 结构完整性

五、CHECKTABLE 页的完整性

六、DBREINDEX 索引

七、INDEXDEFRAG 整理索引碎片

八、SHRINKDATABASE 释放空间

九、SHRINKFILE 释放文件空间

十、HELP 语句的语法信息

一、DBCC CHECKALLOC检查指定数据库的磁盘空间分配结构一致性<单用户模式>。

语法

DBCC CHECKALLOC

(’database_name’[ , NOINDEX<指定不检查非系统表的非聚集索引>|

{REPAIR_ALLOW_DATA_LOSS<同REPAIR_REBUILD但删除已损坏的内容,数据会丢失>

|REPAI*_**ST<进行简单的修复操作,数据不会丢失>

|REPAIR_REBUILD<进行复杂的修复,数据不会丢失>} ])

[WITH{[ALL_ERRORMSGS<显示全部错误信息>|NO_INFOMSGS<不显示错误信息>|][,

[TABLOCK<获取共享表锁> ] ][, [ESTIMATEONLY<显示需要的临时空间tempdb]]}<此四个参数不重要> ]

例:

use ufdata_999_2001

go

ALTER DATABASE ufdata_999_2001 SET SINGLE_USER–SQL7.0下同(sp_dboption ‘ufdata_999_2001′,’single_user’, ‘true’)

go

DBCC CHECKALLOC(’ufdata_999_2001 ‘, REPAIR_REBUILD) with NO_INFOMSGS

go

ALTER DATABASE ufdata_999_2001 SET MULTI_USER–SQL7.0(sp_dboption ‘ufdata_999_2001′,’single_use*’, ‘**lse’)

二、DBCC CHECKCATALOG检查指定数据库中的系统表内及系统表间的一致性。

语法

DBCC CHECKCATALOG (’database_name ” ) [ WITH NO_INFOMSGS ]

例:DBCC CHECKCATALOG (’ufdata_999_2001 ‘) with NO_INFOMSGS

三、DBCC CHECKCONSTRAINTS检查指定表上的指定约束或所有约束的完整性。

语法

DBCC CHECKCONSTRAINTS

[( 'table_name' | 'constraint_name' )][ WITH { ALL_ERRORMSGS

| ALL_CONSTRAINTS<对表上所有启用及禁用的约束进行检查> } ]

例:DBCC CHECKCONSTRAINTS with ALL_CONSTRAINTS

四、 DBCC CHECKDB检查指定数据库中的所有对象的分配和结构完整性<单用户模>。

语法

DBCC CHECKDB

( ‘database_name’ [ , NOINDEX | REPAIR_ALLOW_DATA_LOSS | REPAI*_**ST |

REPAIR_REBUILD } ] ) [ WITH { [ ALL_ERRORMSGS ] [ , [ NO_INFOMSGS ] ]

[ , [ TABLOCK ]] [ , [ ESTIMATEONLY ] ] [ , [ PHYSICAL_ONLY ] ] } ]

例:

use ufdata_999_2001

go

ALTER DATABASE ufdata_999_2001 SET SINGLE_USER

DBCC CHECKDB (ufdata_999_2001, REPAIR_REBUILD) with NO_INFOMSGS

go

ALTER DATABASE ufdata_999_2001 SET MULTI_USER

go

五、DBCC CHECKTABLE检查指定表或视图的数据、索引及 text、ntext 和 image 页的完整性<单用户模式>。

语法

DBCC CHECKTABLE

( ‘table_name’ | ‘view_name’ [ , NOINDEX | index_id|{REPAIR_ALLOW_DATA_LOSS

|REPAI*_**ST | REPAIR_REBUILD } ] ) [WITH { [ ALL_ERRORMSGS

| NO_INFOMSGS ] [ , [ TABLOCK ] ] [ , [ ESTIMATEONLY ] ]

[ , [ PHYSICAL_ONLY ] ] } ]

例:

use ufdata_999_2001

go

ALTER DATABASE ufdata_999_2001 SET SINGLE_USER

go

DBCC CHECKTABLE (’code’, REPAIR_REBUILD) with NO_INFOMSGS

go

ALTER DATABASE ufdata_999_2001 SET MULTI_USER

六、DBCC DBREINDEX重建指定数据库中表的一个或多个索引。

语法

DBCC DBREINDEX

( [ 'database.owner.table_name' [ , index_name [ , fillfactor ]] ])

[ WITH NO_INFOMSGS ]

例:DBCC DBREINDEX (code) with NO_INFOMSGS

七、DBCC INDEXDEFRAG整理指定的表或视图的聚集索引和辅助索引碎片。

语法

DBCC INDEXDEFRAG ( { database_name | database_id | 0 }, { table_name | table_id |

‘view_name’ | view_id }, { index_name | index_id } ) [ WITH NO_INFOMSGS ]

例:DBCC INDEXDEFRAG (ufdata_999_2001,code,ccode_name) with NO_INFOMSGS

八、DBCC SHRINKDATABASE释放指定数据库中的数据文件空间。

语法(SQL7.0用SHRINKDB)

DBCC SHRINKDATABASE

( database_name [ , target_percent<释放后数据库文件中所要的剩余可用空间百分比>]

[ , { NOTRUNCATE<据库文件中保留所释放的文件空间>

TRUNCATEONLY<空间释放给操作系统, target_percent无效 )

例:DBCC SHRINKDATABASE ('ufdata_999_2001',10)

九、DBCC SHRINKFILE释放相关数据库的指定数据文件或日志文件空间。

语法

DBCC SHRINKFILE

( { file_name | file_id }{ [ , target_size<是用兆字节表示的所要的文件大小> ] |

[ , { EMPTYFILE | NOTRUNCATE | TRUNCATEONLY } ] } )

例:

USE ufdata_999_2001

SP_HELPFILE -查看数据库有关信息后修改下面的语句后执行即可

Go

DBCC SHRINKFILE (ufmodel, 70)

DBCC SHRINKFILE (ufmodel_log, 7)

GO

十、DBCC HELP返回指定的 DBCC 语句的语法信息。

语法

DBCC HELP ( ‘dbcc_statement’ | @dbcc_statement_var | ‘?’ )

例:

Dbcc help(’?')