祝愿大家身体健康!

 站点注册  找回密码
 站点注册

QQ登录

只需一步,快速开始

查看: 4219|回复: 0

【转帖】如何检查数据库中数据的一致性

[复制链接]

【转帖】如何检查数据库中数据的一致性

[复制链接]
ehxz

主题

0

回帖

57万

积分

管理员

积分
570764
贡献
在线时间
小时
2004-8-5 20:57:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?站点注册

×
  数据库一致性检查(dbcc)提供了一些命令用于检查数据库的逻辑和物理一致性。Dbcc主要有两个功能:
    1. 使用checkstorage 或 checktable 及 checkdb 在页一级和行一级检查页链及数据指针。
    2. 使用checkstorage, checkalloc, 或 checkverify, tablealloc, 及indexalloc 检查页分配。

  在下列情况中需要使用 dbcc 命令:

    1. 作为数据库日常维护工作的一部分, 数据库内部结构的完整性决定于sa 或dbo 定期地运行 dbcc 检查。
    2. 在系统报错以后, 确定数据库是否有损坏。
    3. 在备份数据库之前, 确保备份的完整性。
    4. 如果怀疑数据库有损坏时, 例如, 使用某个表时报出表损坏的信息, 可以使用 dbcc 确定数据库中其他表是否也有损坏。

  下面是dbcc的简单用法:

  • dbcc checktable (table_name) 检查指定的表, 检查索引和数据页是否正确链接, 索引是否正确排序, 所有指针是否一致, 每页的数据信息是否合理, 页偏移是否合理。
  • dbcc checkdb (database_name) 对指定数据库的所有表做和checktable 一样的检查。
  • dbcc checkalloc (database_name,fix|nofix) 检查指定数据库, 是否所有页面被正确分配, 是否被分配的页面没被使用。当使用"fix"选项时,在检查数据库的同时会自动修复有问题的页面。(若数据库数据量很大,则该过程会持续很长时间。)
  • dbcc tablealloc (table_name,fix|nofix) 检查指定的表, 是否所有页面被正确分配, 是否被分配的页面没被使用。是 checkalloc 的缩小版本, 对指定的表做完整性检查。当使用"fix"选项时,在检查数据表的同时会自动修复数据表中有问题的页面。

  关于上述命令的其它选项及详细使用方法和checkstorage, checkverify, indexalloc 的详细使用方法, 请参阅有关命令手册。

  举例1: Unix平台检查pubs2数据库的一致性

    1. 单用户模式启动Server: $SYBASE/install startserver -f RUN_server_name -m
    2. vi dbcc_db.sql use master go sp_dboption pubs2,"single user",true go use pubs2 go checkpoint go dbcc checkdb(pubs2) go dbcc checkalloc(pubs2,fix) go dbcc checkcatalog(pubs2) go use master go sp_dboption pubs2,"single user",false go use pubs2 go checkpoint go quit go
    3. isql -Usa -Pxxxxxx -SSYBASE <dbcc_db.sql >dbcc_db.out
    4. grep Msg dbcc_db.out

  举例2: Unix平台检查pubs2数据库中titles表的一致性

    1. vi dbcc_table.sql use pubs2 go dbcc checktable(titles) go dbcc tablealloc(titles) go
    2. isql -Usa -Pxxxxxx -SSYBASE < dbcc_table.sql > dbcc_table.out
    3. grep Msg dbcc_table.out
共享共进共赢Sharing And Win-win Results
SYBASEBBS - 免责申明1、欢迎访问“SYBASEBBS.COM”,本文内容及相关资源来源于网络,版权归版权方所有!本站原创内容版权归本站所有,请勿转载!
2、本文内容仅代表作者观点,不代表本站立场,作者自负,本站资源仅供学习研究,请勿非法使用,否则后果自负!请下载后24小时内删除!
3、本文内容,包括但不限于源码、文字、图片等,仅供参考。本站不对其安全性,正确性等作出保证。但本站会尽量审核会员发表的内容。
4、如本帖侵犯到任何版权问题,请立即告知本站 ,本站将及时删除并致以最深的歉意!客服邮箱:admin@sybasebbs.com
您需要登录后才可以回帖 登录 | 站点注册

本版积分规则

免责声明:
本站所发布的一切破解补丁、注册机和注册信息及软件的解密分析文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:Admin@SybaseBbs.com

QQ|Archiver|PowerBuilder(PB)BBS社区 ( 鲁ICP备2021027222号-1 )

GMT+8, 2024-4-28 03:23 , Processed in 0.063984 second(s), 8 queries , MemCached On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表