62库

您现在的位置是:首页 > 前端开发 > Html/Css > 正文

Html/Css

pg数据库恢复误操作 pg数据库备份和恢复

Admin2023-11-11Html/Css77

sql数据库误改怎样恢复

1, 如果你有比较新的备份文件,可以将备份恢复到另外一台机器上,然后将对应表导入到当前库;

2,如果你的日志文件还没有被覆盖,将日志文件copy出去,先备份一下,找个读取sqlserver日志的工具,从日志文件中逐条记录恢复。

oracle数据库误操作把表删除了,怎样恢复

一:表的恢复

对误删的表,只要没有使用PURGE永久删除选项,那么从flash back区恢复回来希望是挺大的。一般步骤有:

1、从flash back里查询被删除的表

select * from recyclebin

2.执行表的恢复

flashback table tb to before drop,这里的tb代表你要恢复的表的名称。

二:表数据恢复

对误删的表记录,只要没有truncate语句,就可以根据事务的提交时间进行选择恢复,一般步骤有:

1、先从flashback_transaction_query视图里查询,视图提供了供查询用的表名称、事务提交时间、UNDO_SQL等字段。

如:select * from flashback_transaction_query where

table_name='TEST';

2、执行表记录恢复

一般先根据时间进行查询,查询语句模式为select * from tb as of timestamp

to_timestamp(time,'yyyy-mm-dd hh24:mi:ss'); tb指表名称,time指某个时间点

如select * from scott.test as of timestamp to_timestamp('2009-12-11

20:53:57','yyyy-mm-dd hh24:mi:ss');

若有数据,恢复极为简单了,语句为flashback table tb to timestamp

to_timestamp(time,'yyyy-mm-dd hh24:mi:ss');

如flashback table scott.test to timestamp to_timestamp('2009-12-11

20:47:30','yyyy-mm-dd hh24:mi:ss');

注意:alter table testvarchar enable row movement;

这个命令的作用是,允许Oracle 修改分配给行的rowid。在Oracle

中,插入一行时就会为它分配一个rowid,而且这一行永远拥有这个rowid。闪回表处理会对EMP

完成DELETE,并且重新插入行,这样就会为这些行分配一个新的rowid。要支持闪回就必须允许Oracle 执行这个操作

如何利用pg_dumpall备份的文件,恢复数据库

一、把SQL2005数据库备份恢复到SQL2005数据库中二、在SQL2005数据库中生成脚本 1、选定数据库--右键--任务--生成脚本 2、下一步--选择数据库 3、下一步--找到“为服务器版本编写脚本”--选择“SQL Server 2000数据库” 4、选择“表”,逐步执行下一步三、执行脚本,在SQL2000数据库中生成数据库结构 1、将脚本文件传输到SQL2000数据库电脑 2、运行SQL 2000的查询分析器 3、将脚本内容复制到查询分析器中,执行脚本内容,生成数据库结构 四、导入数据 1、在SQL 2000数据库中,创建数据库 2、选定数据库--右键--所有任务--导入数据 3、选择数据源--选择服务器--选择数据库 4、选择目的 5、逐步执行下一步

pgsql 我刚不小心执行了update 语句,请问有什么办法回退到原来的值

你知道原来的值吗?update t_so_so_member set receiver_mobile=原值

不知道就看看以前的备份有没有?如果也没有就无法了。

如何将阿里云RDS PgSQL恢复到本地主机中

1. 时间很好理解,其实就是触及这个时间后的XLOG中的第一个事务结束位置作为停止点。

2. 字符串,这个是需要通过pg_create_restore_point函数来创建的一个还原点,需要超级用户调用这个函数。

3. XID也很好理解,就是恢复到指定事务的结束位置。

既然我们已经知道了数据库可以恢复到指定的这几个位置,我们怎么来结合呢?

例如我们在做一笔比较重要的操作前,可以创建一个还原点(但是需要超级用户),不适合阿里云RDS。

postgres=# select pg_create_restore_point('digoal');

pg_create_restore_point

-------------------------

1D6/FB17EC08

(1 row)

阿里云为了防止一些用户的误操作,只开放了普通用户给用户使用,所以有一些东西都无法操作,例如创建检查点,切换XLOG,创建还原点都无法操作。

postgres= checkpoint;

ERROR: must be superuser to do CHECKPOINT

postgres= select pg_switch_xlog();

ERROR: must be superuser to switch transaction log files

postgres= select pg_create_restore_point('ab');

ERROR: must be superuser to create a restore point

时间其实是一个比较模糊的概念,所以也不建议使用,除非是我们没有其他信息,才使用时间。

XID是一个很不错的信息,我们在阿里云就用它了。

首先要创建一个记录还原点XID的表。记录XID,时间,以及描述信息。(来代替pg_create_restore_point系统函数的功能)

postgres= create table restore_point(id serial primary key, xid int8, crt_time timestamp default now(), point text);

CREATE TABLE

创建一个函数,代替pg_create_restore_point的功能,插入还原点。

postgres= create or replace function create_restore_point(i_point text) returns void as $$

declare

begin

insert into restore_point(xid,point) values (txid_current(),i_point);

end;

$$ language plpgsql strict;

CREATE FUNCTION

插入一个还原点

postgres= select create_restore_point('digoal');

create_restore_point

----------------------

(1 row)

查询这个表的信息:

postgres= select * from restore_point;

id | xid | crt_time | point

----+--------+----------------------------+--------

1 | 561426 | 2015-06-19 09:18:57.525475 | digoal

(1 row)

postgres= select * from restore_point where point='digoal';

id | xid | crt_time | point

----+--------+----------------------------+--------

1 | 561426 | 2015-06-19 09:18:57.525475 | digoal

(1 row)

接下来要模拟一下还原:

postgres= create table test(id int,info text);

CREATE TABLE

postgres= insert into test select generate_series(1,1000),md5(random()::text);

INSERT 0 1000

记录当前哈希值。用于恢复后的比对。

postgres= select sum(hashtext(t.*::text)) from test t;

sum

--------------

-69739904784

(1 row)

接下来我要做一笔删除操作,在删除前,我先创建一条还原点信息。

postgres= select create_restore_point('before delete test');

create_restore_point

----------------------

(1 row)

postgres= delete from test;

DELETE 1000

postgres= select * from restore_point where point='before delete test';

id | xid | crt_time | point

----+--------+----------------------------+--------------------

2 | 561574 | 2015-06-19 09:45:28.030295 | before delete test

(1 row)

我只需要恢复到561574 即可。接下来就是模拟恢复了。

但是这个文件可能还没有归档,而pg_switch_xlog()函数又不能用,我们只能主动产生一些XLOG,让RDS触发归档。

postgres= select pg_xlogfile_name(pg_current_xlog_location());

pg_xlogfile_name

--------------------------

000000010000000200000041

(1 row)

postgres= insert into test select generate_series(1,100000);

INSERT 0 100000

postgres= insert into test select generate_series(1,100000);

INSERT 0 100000

postgres= select pg_xlogfile_name(pg_current_xlog_location());

pg_xlogfile_name

--------------------------

000000010000000200000042

(1 row)

已经切换。接下来我们需要下载阿里云RDS的备份和归档到本地。

并且在本地需要安装一个postgresql, 并且与阿里云RDS的编译配置参数一致(例如数据块的大小),最好使用的模块也一致,但是这里没有用到其他模块,所以无所谓。

给阿里云RDS一个建议,最好提供用户一个软件打包,方便用户恢复,降低恢复门槛。

编译项可以使用pg_config命令查看,但是RDS我们没有办法这么查看。通过pg_settings来看吧。

postgres= select name,setting,unit from pg_settings where category='Preset Options';

name | setting | unit

-----------------------+---------+------

block_size | 8192 |

data_checksums | on |

integer_datetimes | on |

max_function_args | 100 |

max_identifier_length | 63 |

max_index_keys | 32 |

segment_size | 131072 | 8kB

server_version | 9.4.1 |

server_version_num | 90401 |

wal_block_size | 8192 |

wal_segment_size | 2048 | 8kB

(11 rows)

postgres= select version();

version

--------------------------------------------------------------------------------------------------------------

PostgreSQL 9.4.1 on x86_64-unknown-linux-gnu, compiled by gcc (GCC) 4.4.6 20110731 (Red Hat 4.4.6-3), 64-bit

(1 row)

本地编译安装PostgreSQL 9.4.1,编译参数与RDS一致。阿里云RDS这几个参数都是默认的。

--with-blocksize=BLOCKSIZE

set table block size in kB [8]

--with-segsize=SEGSIZE set table segment size in GB [1]

--with-wal-blocksize=BLOCKSIZE

set WAL block size in kB [8]

--with-wal-segsize=SEGSIZE

set WAL segment size in MB [16]

关于pg数据库恢复误操作和pg数据库备份和恢复的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

发表评论

评论列表

  • 这篇文章还没有收到评论,赶紧来抢沙发吧~