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(’?')