'DB/ORACLE'에 해당되는 글 14건

  1. 2013.09.27 오라클 DELETE, UPDATE 후 COMMIT 한 데이터 복구하는 방법 2
  2. 2013.08.19 오라클 MERGE INTO - 한번에 INSERT, UPDATE 하기 5
  3. 2013.08.14 ORA-01403
  4. 2013.07.25 ORA-00911: 문자가 부적합합니다.

오라클 DELETE, UPDATE 후 COMMIT 한 데이터 복구하는 방법

DB/ORACLE 2013. 9. 27. 14:24

오라클 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 WHERE USER_ID = 'ITDI'; 


COMMIT; 


위와 같은 방법으로 USER_ID = 'ITDI' 의 데이터를 TEST 테이블에서 삭제를 하고 COMMIT을 하였을 경우, 


SELECT * 

  FROM TEST 

 AS OF TIMESTAMP(SYSTIMESTAMP-INTERVAL '15' MINUTE) 

WHERE USER_ID = 'ITDI' ; 


이렇게 하면 삭제를 한지 15분안의 데이터를 찾아서 조회를 할수 있다. 


복구하는 방법은 CTAS를 써서 임시테이블에 넣어서 차차 복구를 하여도 되고 


다이렉트로 


INSERT INTO TEST 

SELECT * 

  FROM TEST 

 AS OF TIMESTAMP(SYSTIMESTAMP-INTERVAL '15' MINUTE) 

WHERE USER_ID = 'ITDI' ; 


이렇게 처리를 하여도 된다. 


일단 서버를 셋팅을 하게되고 중요한 운영DB일 경우에는 이와같은 방법으로 


데이타의 삭제를 예방할 수 있다. 


DMP 백업이나 ARCHIVE 백업등의 처리 또한 백업의 종류이기는 하나, 


위와 같은 방법이 백업복구의 대처 능력이 다른 복구작업보다 더 좋다고 생각한다.




출처 - http://www.itdi.co.kr/onuri/bbs/board.php?bo_table=04_2&wr_id=157&sfl=wr_subject&stx=de&sop=and

:

오라클 MERGE INTO - 한번에 INSERT, UPDATE 하기

DB/ORACLE 2013. 8. 19. 18:28
DB 테이블을 다룰 때, 특정 조건의 데이터가 존재하는 경우에는 해당 row를 원하는 값으로 update하고, 없는 경우에는 새로운 데이터를 insert를 해야하는 경우가 왕왕 있습니다. 이럴 때 보통은 select 쿼리를 먼저해보고 데이터가 있는지 없는지 판단을 해서 update를 할 지 insert를 할 지 분기해서 처리했었는데요. oracle에서 MERGE INTO라는 구문을 쓰면 하나의 쿼리로 두가지 경우에 모두 대처할 수 있습니다. 

아래와 같이 쓰면 됩니다. table을 지정했기 때문에 MATCHED, NOT MATCHED 이하에 update문과 insert문에 table_name은 생략됩니다.

MERGE INTO table_name alias
            USING (table | view | subqueryalias                -- 하나의 테이블만 이용한다면 DUAL 활용
                 ON (join condition)                                     -- WHERE절에 조건 쓰듯이
            WHEN MATCHED THEN                                   -- ON 이하의 조건에 해당하는 데이터가 있는 경우 
                     UPDATE SET col1 = val1[, ...]                -- UPDATE 실행
            WHEN NOT MATCHED THEN                           -- ON 이하의 조건에 해당하는 데이터가 없는 경우
                     INSERT (column lists) VALUES (values);  -- INSERT 실행

예 1) 
MERGE INTO copy_emp c
            USING employees e
            ON (c.employee_id = 200911)
            WHEN MATCHED THEN
                      UPDATE SET
                            c.first_name = e.first_name,
                            c.last_name = e.last_name,
                            c.email = e.email,
                            ......
            WHEN NOT MATCHED THEN
                      INSERT (c.employee_id, c.first_name, c.last_name, ...... ) 
                                 VALUES (e.employee_id, e.first_name, e.last_name, ...... );

예 2) 테이블을 하나만 쓸 경우
MERGE INTO emp
            USING DUAL
            ON (employee_id = 200911)
            WHEN MATCHED THEN
                      UPDATE SET
                            first_name = 'John',
                            last_name = 'Petrucci',
                            email = 'dream@johnpetrucci.com',
                            ......
            WHEN NOT MATCHED THEN
                      INSERT (first_name, last_name, email, ...... ) 
                                 VALUES ('John', 'Petrucci', 'dream@johnpetrucci.com', ...... );

Oracle 10g 이후에는 WHEN MATCHED, WHEN NOT MATCHED 이하의 update, insert 구문에도 where절을 쓸 수 있습니다. 


:

ORA-01403

DB/ORACLE 2013. 8. 14. 14:18

프로시져 작성시 SELECT INTO 에서 조회된 쿼리의 ROW가 존재하지 않을때 ORA-01403 에러발생 대치


1. 에러를 잡는 방법 : 서브블럭을 이용한 Exception 처리 
BEGIN 

BEGIN 
SELECT id INTO vMemid FROM a.t_members WHERE perid = :new.perid; 
EXCEPTION 
WHEN NO_DATA_FOUND THEN 
Null; 
END; 

END; 


2, 에러를 피하는 방법 : 그룹함수를 이용한 무조건 1행 반환) 
BEGIN 
SELECT MAX(id) INTO vMemid FROM a.t_members WHERE perid = :new.perid; 
END;

:

ORA-00911: 문자가 부적합합니다.

DB/ORACLE 2013. 7. 25. 15:29

"ORA-00911: 문자가 부적합합니다."

sqlmap.xml에 들어가는 쿼리 마지막에 

" ; " 세미콜론을 빼야한다.

" ; " 세미콜론을 빼야하는데 고걸 지우지않고 그대로 옮겨넣어서 비롯된 실수.

[출처] ORA-00911: 문자가 부적합합니다.|작성자 wenaon


: