oracle怎么撤销更新,oracle修改数据

oracle update后怎么保存或者取消更新啊

输入COMMIT;就代表确定

十年的兴安网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整兴安建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联建站从事“兴安网站设计”,“兴安网站推广”以来,每个客户项目都认真落实执行。

如果更新后你还没COMMIT;那输入rollback;就取消了

要是已经COMMIT;了想取消,那就麻烦一点,要用到flashback table功能闪回表,具体用法可以GOOGLE下

如何撤销一个已经执行的更新SQL语句?

下次要是没把握时,先启动一个事务

象这样

BEGIN TRANSACTION --启动一个事务

UPDATE TABLENAME SET XXXXX WHERE XXXX

SELECT * FROM TABLENAME --查看结果

--如果发现有问题就执行这个语句:

ROLLBACK TRANSACTION

--没问题就迅速执行这个语句:

COMMIT TRANSACTION

这些都要先写好了,执行完成后要迅速执行事务提交或回滚语句。

以免启动事务影响其它人对更改过的表的访问。

oracle 更新错了的数据怎么恢复

恢复ORACLE被误更新或删除数据的方法

有时我们在操作ORACLE数据库的时候,可能由于SQL写错了导致把数据update错了,或者delete删除掉了,那么这时候如何去恢复之前的数据呢?

莫着急,我们可以采用oracle的基于时间查询as of timestamp的办法进行恢复数据。下面以具体例子进行讲解用法。

1、比如,我的wl_notify_task表目前有三条数据,大家重点关注PARAMETER字段。

2、我现在做一个update操作,要把id=1的parameter字段更新为param_test8,但是由于我操作的失误,id=1条件忘了加了,导致整表更新了。导致其他记录的parameter字段全部都是param_test8

update wl_notify_task set parameter = ‘param_test8′

杯具发生了,那么如何再找到我之前的记录是什么呢??

3、没事,我们可以采用oracle的基于时间查询的办法查询出3分钟前的表的记录情况,查询SQL如下:

SELECT * FROM wl_notify_task  AS OF TIMESTAMP SYSDATE – 3/1440

对SQL的解释说明:

SYSDATE :当前时间

1440 :24h*60m=1440m

3:3分钟前

4、通过上面的查询,我们看到了在update之前的数据情况。那么把数据恢复回去就很简单了,通过ID关联的方式更新回去即可。如下:

update wl_notify_task t1 

set t1.parameter = 

(select parameter 

from wl_notify_task AS OF TIMESTAMP SYSDATE – 3 / 1440 

where t1.id = id)

这种做法也是DBA常用的恢复数据的手段。对于删除的情况,那么就通过insert办法重新把记录插入表即可。

最后需要 特别提醒大家注意 的是,SQL中的  SYSDATE-3/1440  代表查询3分钟前的记录情况,由于是和当前时间SYSDATE的距离3分钟前,所以这个随着隔的时间不同及时间的推移是会变化的,一般的做法是在真正做恢复时的update前,需要先select查询一下比如3分钟前的数据是否是我们想要的数据,确认无误后立即做恢复的update。如果数据不是我们想要的,那么就需要通过调节分钟数直到找到我们想要的数据。这种办法适合小批量数据,如果是大批量数据且很重要的数据的话,建议大家新建一张结构相同的表,先把as of timestamp查询出来的数据存到新表中,再进行恢复操作,因为这样数据不再受时间差的影响,确保数据是准确的,无论你何时开始做恢复操作。

oracle更新表字段错了怎么恢复

通过下面的语句看看是否能查到未改之前的记录数据:

SELECT * FROM table_name AS OF TIMESTAMP SYSDATE – 40/1440;

在这里SYSDATE – 40/1440的意思是向前推40分钟,时间可以根据当时操作时间的情况来任意更改,如果查到之前没修改时的数据,那我们就可以使用下面的语句来恢复之前的记录了:

update table_name t1 set t1.param = (SELECT param FROM table_name AS OF TIMESTAMP SYSDATE – 40/1440 where t1.id = id);

这里是通过id来关联的,这个可以根据实际情况变动。


网站名称:oracle怎么撤销更新,oracle修改数据
链接地址:http://pwwzsj.com/article/hspopc.html