오라클 UPDATE 후 COMMIT 한 데이터 복구방법오라클 UPDATE 후 COMMIT 한 데이터 복구방법
Posted at 2019. 10. 16. 11:21 | Posted in DataBase오라클 COMMAND 창에서 아래처럼 쳐보면
sql> show parameter undo;
undo_management
undo_retention
undo_tablespace
속성들에 대한 정보가 나오게
된다.
그 중 undo_retention 은 delete, update 후에 ROLLBACK이 아닌 COMMIT을 하였을때 부터
속성값의 초 까지는 오라클에서 임시로 저장을 하게끔 되어있다.
DEFAULT 속성값은 '900' 으로 900/60초
= 15분
COMMIT 후 15분 안에는 데이터를 복구 할 수 있게 된다.
그 시간을 늘리거나 줄이려면
'alter system set undo_retention = 1500 ; ' --1500초(25분)
이렇게 늘릴수가 있다.
지금까지는 복구를 위한 셋팅 방법이었으며, 이제는 복구 방법을 알아보자.
복구를 하는 방법은
DELETE FROM TEST_DB WHERE USER_ID = 'STORYERP';
COMMIT;
위와 같은 방법으로 USER_ID = 'STORYERP' 의 데이터를 TEST 테이블에서 삭제를 하고
COMMIT을 하였을 경우,
SELECT *
FROM TEST_DB
AS OF
TIMESTAMP(SYSTIMESTAMP-INTERVAL '15' MINUTE)
WHERE USER_ID = 'STORYERP' ;
이렇게 하면 삭제를 한지 15분안의 데이터를 찾아서 조회를 할수 있다.
복구하는 방법은 CTAS를 써서 임시테이블에
넣어서 차차 복구를 하여도 되고
DIRECT로
INSERT INTO TEST_DB
SELECT *
FROM
TEST_DB
AS OF TIMESTAMP(SYSTIMESTAMP-INTERVAL '15' MINUTE)
WHERE USER_ID =
'STORYERP' ;
이렇게 처리를 해도 된다.
일단 서버를 셋팅을 하게되고 중요한 운영DB일 경우에는 이와같은
방법으로
데이타의 삭제를 예방할 수 있다.
DMP 백업이나 ARCHIVE 백업등의 처리 또한 백업의 종류이기는
하나,
위와 같은 방법이 백업복구의 대처 능력이 다른 복구작업보다 더 좋다고 생각한다.
'DataBase' 카테고리의 다른 글
[oracle 10g]오라클 한글깨짐 현상 해결방법 (0) | 2019.10.22 |
---|---|
Table 목록 가져오기 (0) | 2019.10.16 |
오라클 export 및 import (0) | 2013.08.30 |
archive mode로 변경 (0) | 2013.08.30 |
Table Import (0) | 2013.08.30 |
크론탭 특정일(ex 30일)이 지난 파일 삭제 및 디렉토리 이동하기크론탭 특정일(ex 30일)이 지난 파일 삭제 및 디렉토리 이동하기
Posted at 2013. 9. 12. 09:50 | Posted in Server다음내용으로 실행파일을 하나 만들어 매일 특정시간에 호출되도록 크론탭(crontab)에 등록하시면 자동으로 파일자료를 삭제 및 이동하실수있습니다.
크론탭 사용방법
crontab -e : 크론탭 설정 변경/등록하기
crontab -l : 현재 설정되어 있는 크론탭 정보 확인
▷10 2 * * 0-2 /root/backup.sh
2. 1시에서 6시 사이에 2시간 마다 30분에 실행
▷ 30 1-6/2 * * *
3. 매달 1일 1시에 실행
▷ 0 1 1 * *
'Server' 카테고리의 다른 글
telnet 막고 ftp만 권한 주기 (0) | 2013.09.27 |
---|---|
httpd.conf 도메인 / 붙이지 않아도 실행되게 설정하는 방법 (0) | 2013.09.27 |
mysql 리플리케이션으로 DB 백업 (0) | 2013.09.12 |
호스트네임 바꾸기 (0) | 2013.09.11 |
ncftp 를 이용한 백업 스크립트 (0) | 2013.09.10 |