Database

(Oracle) delete 복구

steloflute 2012. 11. 9. 23:30

http://dearhwan.egloos.com/4092555

 

다음과 같이

DELETE FROM AAA;
COMMIT;

실수로 AAA TABLE 내용을 전부 삭제 하고 COMMIT을 날렸으면...
복구 하기 위해
DBA한테 요청하고 복잡한 과정을 겪게 될 겁니다.

SELECT * FROM AAA;

를 치면 NO_DATA_FOUND 나오겠지요.

하지만

SELECT * FROM AAA
AS OF TIMESTAMP (SYSTIMESTAMP - INTERVAL '10' MINUTE);

라고 치면... 10분전에 저장되어 있던. DATA가 쭈욱... 나올겁니다.
COMMIT됐는데도 나온단 말이죠.

눈치빠르신 분은 아시겠지만

'10' MINUTE 라는 것이 10분전 DATA를 불러오는 것이고요.
'5' HOUR 로 치면 5시간 전 DATA를 불러올 수 있지요..

오라클에서 지원하는 flash back이라는 기능인데요..

여러모로 유용하게 사용하고 있습니다.

DATA가지고 거짓말 하시는분들 조심하셔야 돼요.

그럼 이만

 

 


http://blog.daum.net/njaewon/22

 

오라클 삭제한 데이터 복구 방법

오늘 실수로 개발 서버 DB의 테이블의 데이터를 살짝 날려 버렸는데, 리얼 서버 DB의 데이터를 insert 쿼리로 긁어서 다시 넣을 까, 하다 옆에 분에게 물어보니 이런 멋진 쿼리를 알려 주셨다.

insert into [대상테이블]
select * from [대상테이블] as of timestamp (systimestamp-interval '30' minute)[조건절];

systimestamp-interval은 데이터를 되돌릴 수 있는 시간(분)이라고 한다. 최대 30분이라고 하니 날려 먹었다고 생각한 순간, 시간을 계산해서 실행하고 데이터를 확인해보도록 한다.

  • 검색해보니 오라클 9i 이후부터 지원한다.
  • ora-1555: 너무이전 스냅샷, ora-22924: 너무오래된 스냅샷입니다. –> 이런 에러가 발생할 경우 조건절을 주어서 데이터를 조금씩 잘라서 가져옵니다.
  • delete 와 같은 DML 쿼리 실행 시 한번 더 생각하는 습관을 가져야겠습니다.

 

 

'Database' 카테고리의 다른 글

Oracle SQL Where clause to find date records older than 30 days  (0) 2013.01.16
(Oracle) Comparing Dates  (0) 2013.01.04
(Oracle) data pump 권한 주기  (0) 2012.11.05
(Oracle) Compressed Table  (0) 2012.10.31
오라클 접속 로그  (0) 2012.10.19