新闻 | 天津 | 民生 | 广电 | 津抖云 | 微视 | 读图 | 文娱 | 体育 | 图事 | 理论 | 志愿 | 专题 | 工作室 | 不良信息举报
教育 | 健康 | 财经 | 地产 | 天津通 | 旅游 | 时尚 | 购物 | 汽车 | IT | 亲子 | 会计 | 访谈 | 场景秀 | 发布系统

"津云"客户端
  您当前的位置 :北方网 > IT浪潮 > 滚动新闻 正文
关键词:

如何应用SQL Server中的DBCC避免堵塞


http://www.enorth.com.cn  2007-09-12 23:17

  本文说明为何应该了解数据库一致性检测(DBCC),还解释如何运行DBCC及应用它的五个扩展。

  在危急时刻,数据库一致性检测(DBCC)可能是你最重要的工具。本文向你简单介绍DBCC的功能,它们包括:

  ◆检测表和相关目录的完整性。

  ◆检测整个数据库。

  ◆检测数据库页的完整性。

  ◆重建任何指定表中的目录。

  你为何需要学习DBCC

  如果你甚至还不知道为何使用DBCC,下面提供一些原因:

  ◆需要不断分割数据库页(表和目录),这可能会破坏分配。

  ◆目录可能遭到破坏,或效率降低。

  ◆SQL Server引擎有时会误解你的意图。

  ◆需要大量更新时,事情可能会很麻烦(记住,任何指定的更新实际为删除和插入)。

  ◆单个页面,虽然仍然“健康”,但可能会失去它们的最优存储足迹。

  bitsCN_net中国网管博客

  如何运行DBCC

  你可以用两种方法运行DBCC:通过命令行窗口或查询分析器(Query Analyzer)窗口。如果你认为必要,你还可以确定其操作的时间。(我从未感到有必要这样做,因为在微软的所有产品中,我对SQL Server的稳定性最为自信。我认为它是雷蒙德推出的最佳产品。但是,感觉也可能出错。)

  DBCC命令包括以下扩展:

  ◆CheckDB:检测整个数据库的一致性,是检查数据库破坏的基本方法。

  ◆CheckTable:检测特定表的问题。

  ◆CheckAlloc:检测数据库的单个页面,包括表和目录。

  ◆Reindex:重建某个特定表的目录。

  ◆CacheStats:说明当前存储在内存缓存中的对象。

  ◆DropCleanBuffers:释放当前存储在缓冲区中的所有数据,这样你就可以继续进行检测,而不必使用前面的结果。

  ◆Errorlog:删除(缩短)当前日志。你可以考虑确定包含这个命令的操作的时间,一个星期左右运行一次。

  www.bitsCN.net网管博客等你来搏

  ◆FlushProclnDB:清除特定数据库的存储过程缓存(使用它的数据库id而不是名称)。使用下列代码找出id:

  SELECT dbid FROM master.dbo.sysdatabases

  WHERE name = '

  IndexDefrag:减少目录分裂,但不给文件加锁,以便用户能够继续应用数据库。

  CheckCatalog:检测特定数据库表及表之间的一致性(后者意味着使用外键等。)

  如何使用这五个扩展

  DBCC首先建立一个数据库快照(在某些情况下,如应用一个Master、TempDB或只读数据库时)。附带条件:要使用DBCC,数据库必须处于单用户模式。

  使用DBCC CheckDB bbs.bitsCN.com国内最早的网管论坛

  此命令保证:

  ◆数据与目录页正确连接。

  ◆目录被正确分类,并保持最新。

  ◆指针一致。

  ◆每个页面的数据保持最新。

  ◆页面偏移值保持最新。

  以下是使用CheckDB的最常见方法:

  DBCC CHECKDB ('AdventureWorks', REPAIR_FAST)

  DBCC CHECKDB ('AdventureWorks', REPAIR_REBUILD)

  DBCC CHECKDB ('AdventureWorks', REPAIR_ALLOW_DATA_LOSS)

  你还可以指定其它几个选项,但以上是三个最重要的选项。我按顺序列出这些DBCC命令,你应该先运行它们,然后检查结果。前两个选项不会造成数据损失,但第三个选项会引起数据损失。因此建议把第三个命令放在一个事务内,如果数据损失不可接受,你可以执行一次回滚(ROLLBACK)。

  使用DBCC CheckTable

  大多数情况下,你遇到的问题往往与数据库中的一个或几个表,而不是整个数据库有关。这时即可运行CheckTable。首先,使用相关数据库,然后运行DBCC CheckTable命令。下面是两个例子: www.bitsCN.net网管博客等你来搏

  DBCC CheckTable ('Sales,SalesOrderHeader')

  DBCC CheckTable ('Sales,SalesOrderHeader', REPAIR_REBUILD)

  使用DBCC CheckAlloc

  这个命令检测数据页及其目录的一致性。下面是两个例子:

  DBCC CHECKALLOC ('Sales.SalesOrderDetails')

  DBCC CHECKALLOC ('Sales.SalesOrderDetails', REPAIR_REBUILD)

  使用DBCC CheckCatalog

  使用这个命令来验证一个数据库系统表的一致性。你指定数据库的名称进行检查,自变量WITH NO_INFOMSGS可选。下面是一个例子:

  DBCC CHECKCATALOG ('AdventureWorks')

  使用DBCC ReIndex

  这个命令促使某个特定的表或视图中的一个或几个目录进行重建。你还可以应用某个特定目录的名称和填充系数。列表A中包含两个例子。第三个自变量说明我希望使用重建目录中的一个90%的填充系数。

  DBCC REINDEX ('AdventureWorks.Sales.SalesOrderHeader', dl.bitsCN.com网管软件下载

  PK_SalesOrderHeader_SalesOrderID'

  DBCC REINDEX ('AdventureWorks.Sales.SalesOrderHeader', PK_SalesOrderHeader_SalesOrderID', 90)

编辑 赵国栋 天极ChinaByte
[进入IT论坛]
请您文明上网、理性发言并遵守相关规定,在注册后发表评论。
 北方网精彩内容推荐
无标题文档
天津民生资讯
天气交通 天津福彩 每月影讯 二手市场
空气质量 天津股票 广播节目 二手房源
失物招领 股市大擂台 天视节目 每日房价
热点专题
北京奥运圣火传递和谐之旅 迎奥运 讲文明 树新风
解放思想 干事创业 科学发展 同在一方热土 共建美好家园
2008天津夏季达沃斯论坛 《今日股市观察》视频
北方网网络相声频道在线收听 2008高考招生简章 复习冲刺
天津自然博物馆馆藏精品展示 2008年天津中考问题解答
带你了解08春夏服饰流行趋势 完美塑身 舞动肚皮舞(视频)
C-NCAP碰撞试验—雪佛兰景程 特殊时期善待自己 孕期检查
热点新闻排行 财经 体育 娱乐 汽车 IT 时尚 健康 教育

Copyright (C) 2000-2021 Enorth.com.cn, Tianjin ENORTH NETNEWS Co.,LTD.All rights reserved
本网站由天津北方网版权所有