人大金仓数据库KingbaseES闪回相关介绍

关键字:

KingbaseES、闪回、闪回表、闪回查询、人大金仓

什么是闪回

在数据库中,闪回是一种用于恢复或回退数据库状态的技术。它允许数据库管理员或开发人员在数据库表数据被修改或删除后,将数据库恢复到之前的某个时间点的状态。

通过使用闪回技术,可以避免数据丢失或错误修改的影响。它可以用于撤销误操作、还原被删除的数据、修复错误的更新或恢复数据库到之前正常工作的状态。

需要注意的是,闪回技术只能在一定的时间范围内进行数据恢复,因为数据库中的历史数据可能会被清理或覆盖。因此,在使用闪回技术时,需要谨慎选择恢复点,并确保数据库的配置和设置能够支持闪回操作。

KingbaseEs支持的闪回类型

  • 闪回删除表

闪回删除表功能为用户提供一种误删表后,还原表的一种手段,无需从备份中进行完整的恢复操作,将表闪回到删除之前的状态

  • 闪回查询

闪回查询能返回用户指定历史时刻的快照数据,用以查看历史时刻的数据状态

  • 闪回版本查询

闪回版本查询允许查看表在历史上不同版本或时间点的数据,它可以让用户比较和分析表数据在不同时间点的变化

  • 闪回表到指定时间点

闪回表到指定的时间点,实际上为用户提供了还原数据的一种手段,如果说闪回查询能够帮助用户查询历史时刻的数据,那么闪回表实际上是帮助用户彻底的找回数据

KingbaseEs中使用闪回相关的前置条件

  • 闪回删除表

闪回删除表依赖于回收站是否记录被删除的表,只有开启回收站功能后,删除的表会进入回收站,才能进行闪回删除表的操作,开启回收站功能,设置kdb_flashback.db_recyclebin=on并重载配置文件生效

  • 闪回查询、闪回版本查询、闪回表到指定时间点

上述三类闪回技术需要依赖提交的时间戳,因此需要开启track_commit_timestamp 这个参数。另外闪回查询还需要开启kdb_flashback.enable_flashback_query 的参数。目前初始化数据库默认情况下kdb_flashback.enable_flashback_query是开启的状态,只需要开启track_commit_timestamp即可。设置track_commit_timestamp =on并重启数据库生效

KingbaseEs闪回相关使用示例

闪回删除表

sql 复制代码
alter system set kdb_flashback.db_recyclebin=on;--设置参数为on

create table test (a int,b int);

insert into test values (1,2);

drop table test;

select * from test;

flashback table test to before drop;--进行闪回删除表操作

select * from test;

闪回查询和闪回版本查询

sql 复制代码
show track_commit_timestamp;--参数为on时,才能使用闪回查询和闪回版本查询

create table tss(a int,b varchar(30));

insert into tss values(1,'a');

\set 'tp1' `date "+%Y-%m-%d %H:%M:%S.%N"`

insert into tss values(2,'b');

\set 'tp2' `date "+%Y-%m-%d %H:%M:%S.%N"`

delete from tss;

\set 'tp3' `date "+%Y-%m-%d %H:%M:%S.%N"`

select * from tss;

select * from tss as of timestamp :'tp1';--闪回查询(通过具体时间点)

select Versions_startscn,versions_endscn,Versions_xid,Versions_operation,* from tss versions between timestamp minvalue and maxvalue;--闪回版本查询(通过具体时间点)

select * from tss as of scn 65536000032;--闪回查询(通过scn)

select Versions_startscn,versions_endscn,Versions_xid,Versions_operation,* from tss versions between csn minvalue and maxvalue;--闪回版本查询(通过scn)

闪回表到指定时间点

用例基于上述闪回查询和闪回版本查询中的用例继续演示

sql 复制代码
select * from tss;

flashback table tss to timestamp :'tp2';--通过指定具体时间点进行闪回

select * from tss;

flashback table tss to scn 65536000032;--通过指定scn进行闪回

select * from tss;
相关推荐
云和数据.ChenGuang4 小时前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
woshilys5 小时前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi5 小时前
SQL注入的那些面试题总结
数据库·sql
建投数据6 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi7 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀7 小时前
Redis梳理
数据库·redis·缓存
独行soc7 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天7 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺7 小时前
分布式系统架构:服务容错
数据库·架构
独行soc8 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘