如何检查数据库中数据的一致性?

简介:

数据库一致性检查(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
本文转自holy2009 51CTO博客,原文链接:http://blog.51cto.com/holy2010/362379
相关文章
|
30天前
|
存储 Oracle 关系型数据库
Dataphin常见问题之想要周期执行任务如何解决
Dataphin是阿里云提供的一站式数据处理服务,旨在帮助企业构建一体化的智能数据处理平台。Dataphin整合了数据建模、数据处理、数据开发、数据服务等多个功能,支持企业更高效地进行数据治理和分析。
|
1月前
|
SQL 开发框架 JavaScript
在 Vue 中进行数据持久化时,有哪些常用的数据库框架?
在 Vue 中进行数据持久化时,有哪些常用的数据库框架?
49 3
|
1月前
|
存储 数据管理 数据处理
数据之光:探索数据库技术的演进之路
数据之光:探索数据库技术的演进之路
60 1
|
1月前
|
存储 运维 关系型数据库
数据的力量:构筑现代大型网站之数据库基础与应用
数据的力量:构筑现代大型网站之数据库基础与应用
49 0
|
1月前
|
SQL 关系型数据库 数据库
事务隔离级别:保障数据库并发事务的一致性与性能
事务隔离级别:保障数据库并发事务的一致性与性能
|
1月前
|
SQL Java 数据库连接
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
17 0
|
6天前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
处理爬取的数据,可存储为txt、csv(适合表格数据)或json(适合结构化数据)文件。若需存储大量数据并执行复杂查询,可选择关系型(如MySQL)或非关系型(如MongoDB)数据库。以MySQL为例,需安装数据库和Python的pymysql库,创建数据库和表,然后编写Python代码进行数据操作。选择存储方式应考虑数据类型、数量及后续处理需求。
14 1
|
7天前
|
SQL 关系型数据库 MySQL
关系型数据库插入数据的语句
使用SQL的`INSERT INTO`语句向关系型数据库的`students`表插入数据。例如,插入一个`id`为1,`name`为&#39;张三&#39;,`age`为20的记录:`INSERT INTO students (id, name, age) VALUES (1, &#39;张三&#39;, 20)。如果`id`自增,则可简化为`INSERT INTO students (name, age) VALUES (&#39;张三&#39;, 20)`。
6 2
|
7天前
|
SQL 存储 Oracle
关系型数据库查询数据的语句
本文介绍了关系型数据库中的基本SQL查询语句,包括选择所有或特定列、带条件查询、排序、分组、过滤分组、表连接、限制记录数及子查询。SQL还支持窗口函数、存储过程等高级功能,是高效管理数据库的关键。建议深入学习SQL及相应数据库系统文档。
9 2
|
13天前
|
人工智能 Cloud Native 算法
数据之势丨AI时代,云原生数据库的最新发展趋势与进展
AI与云数据库的深度结合是数据库发展的必然趋势,基于AI能力的加持,云数据库未来可以实现更快速的查询和决策,帮助企业更好地利用海量数据进行业务创新和决策优化。
数据之势丨AI时代,云原生数据库的最新发展趋势与进展

热门文章

最新文章