首页 > 数据库 >openGauss学习笔记-127 openGauss 数据库管理-设置账本数据库-修复账本数据库

openGauss学习笔记-127 openGauss 数据库管理-设置账本数据库-修复账本数据库

时间:2023-11-19 23:04:45浏览次数:36  
标签:repair 修复 text 数据库 ledger openGauss 账本

openGauss学习笔记-127 openGauss 数据库管理-设置账本数据库-修复账本数据库

127.1 前提条件

  • 系统中需要有审计管理员或者具有审计管理员权限的角色。
  • 数据库正常运行,并且对防篡改数据库执行了一系列增、删、改等操作,保证在查询时段内有账本操作记录结果产生。

127.2 背景信息

  • 当在异常情况或表被损坏时需要使用账本数据库的函数章节中的ledger_gchain_repair(text, text)或ledger_hist_repair(text, text)接口对全局区块表或用户历史表进行修复,修复后调用全局区块表或用户历史表校验接口结果为true。

  • 修复用户历史表的接口为pg_catalog.ledger_hist_repair,操作为:

    SELECT pg_catalog.ledger_hist_repair(schema_name text,table_name text);
    

    如果修复成功,函数返回修复过程中用户历史表hash的增量。

  • 归档全局区块表的接口为pg_catalog.ledger_gchain_repair,操作为:

    SELECT pg_catalog.ledger_gchain_repair(schema_name text,table_name text);
    

    如果修复成功,函数返回修复过程中全局区块表hash的增量。

127.3 操作步骤

  1. 执行历史表修复操作。

    openGauss=# SELECT pg_catalog.ledger_hist_repair('ledgernsp', 'usertable');
    

    查询结果如下:

     ledger_hist_repair
    --------------------
     84e8bfc3b974e9cf
    (1 row)
    

    该结果表明当前节点用户历史表修复成功,修复造成的用户历史表hash增量为84e8bfc3b974e9cf。

  2. 执行全局区块表修复操作。

    openGauss=# SELECT pg_catalog.ledger_gchain_repair('ledgernsp', 'usertable');
    

    查询结果如下:

     ledger_gchain_repair
    ----------------------
     a41714001181a294
    (1 row)
    

    该结果表明,全局区块表修复成功,且插入一条修复数据,其hash值为a41714001181a294。

标签:repair,修复,text,数据库,ledger,openGauss,账本
From: https://blog.51cto.com/shuchaoyang/8475797

相关文章

  • 实现数据库的读写分离
    简介轻量级Java框架,在Java的JDBC层提供额外服务,以jar包的形式提供服务(增强版数据库连接驱动)。适用于基于JDBC的ORM框架、支持第三方数据库连接池、支持实现了JDBC规范的数据库。 读写分离:基于已配置好主从复制的多个数据库。 使用步骤在springboot项目中使用。一、......
  • 【Django使用】django经验md文档10大模块。第4期:Django数据库增删改查
    Django的主要目的是简便、快速的开发数据库驱动的网站。它强调代码复用,多个组件可以很方便的以"插件"形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己的工具包。这使得Django具有很强的可扩展性。它还强调快速开发和DRY(DoNotRepeatYourself)原......
  • 数据库分片
    数据库的分片是一种在多个节点上分割和存储数据的技术。它可以提高数据库的性能、可扩展性和容错能力。下面是一个一般性的数据库分片过程:设计分片键:选择一个合适的字段作为分片键,例如用户ID、地理位置等。分片键应该具有较好的均匀性,以确保数据分布相对平衡。确定分片策略:根据业务......
  • NoSQL数据库类型简介
    NoSQL数据库类型简介近些年来,NoSQL数据库的发展势头很快。据统计,目前已经产生了50到150个NoSQL数据库系统。但是,归结起来,可以将典型的NoSQL划分为4种类型,分别是键值数据库、列式数据库、文档数据库和图形数据库,如图1所示。图14种类型的NoSQL数据库图2键值......
  • 通过PowerShellPlus示例脚本学习PowerShell-连接SQLServer数据库
    ##=====================================================================##Title:Connect-MSSQL-IPSQLAuth##Description:Connectto$ServerNameusingSQLServerauthentication.##Thisconnectionisnotencrypted.##......
  • oracle19cPDB数据库连不上,提示ORA-01109: database not open
    今天尝试创建了一个RAC环境的PDB数据库,在本地执行alterpluggabledatabasepdb01open成功了,但是使用上去了plus连接还是连接不上,提示错误如下:C:\Users\Administrator>sqlplussystem/[email protected]:1521/pdb01SQL*Plus:Release19.0.0.0.0-Productionon星期日1......
  • ORALE学习第三天心得:深入理解数据库管理系统
    在过去的三天里,我深入学习了Oracle数据库管理系统的相关知识。通过理论学习、实践操作和问题解决,我对关系型数据库有了更深入的理解,并且掌握了一些实用的技能。在这篇技术文章中,我将分享我的学习心得,并提供一些相关的源代码示例。一、关系型数据库管理系统概述关系型数据库管理系统......
  • 25届实习秋招-Java面试-MySQL数据库面试题整理-牛客网近一年
    MySQL概述:关系型数据和非关系型数据库的区别,有哪些应用场景有哪些非关系的单表操作:三种SQL语言类型,MySql本身常用命令DDL-数据定义语句:表的常用操作truncate/delete--drop操作的区别varchar最大字节数DMLUpdate语句的sql执行流程对行数据的修改是......
  • Flutter应用-使用sqflite升级数据库
    问题描述使用fluttter开发的应用程序发布后,发现数据库有些设计不合理。如何来更新数据库呢?使用sqflite来处理数据库,但是第一版软件发布后,发现数据库不太合理要改动,想新的应用安装启动后更新数据库。下面以将一张表名称叫timerdata的表在新版应用启动时将这张表的名称改为taskdat......
  • 大型数据库实验七
    ......