728x90

오류 내용

ORA-39001 invalid argument value
ORA-39000 bad dump file specification
ORA-31619 invalid dump file “/덤프파일경로/파일이름“
ORA-27072 file i/o error

해결 방법

위의 오류 내용은 Export dump 백업이 아니라 기본 Export 백업으로 생성된 파일인데 Import dump 백업을 사용해 파일을 Import 할 때 발생되는 오류입니다. 위의 해결방법은 기본 Export로 백업을 진행하는 것이 아니라 Export dump를 사용해서 백업 파일을 생성하는 방법과 기본 Import로 Export 된 파일을 Import 받는 방법 2가지가 있습니다. 기본 Export 된 파일을 기본 Import로 파일을 Import 받았는데 속도가 너무 느리고 사용할 수 있는 옵션도 dump에 비해 사용할 수 있는 옵션이 적어 다시 Dump를 받을 수 있으면 Dump를 받는 것을 추천드립니다.

728x90

'Oracle > 오라클 이관' 카테고리의 다른 글

DataDump가 아닌 기본 exp, imp  (0) 2023.04.18
728x90

개요

이번에 데이터베이스 이관 프로젝트를 진행하면서 DataDump가 아닌 기본 exp, imp를 해야 하는 일이 발생되어 schema별로 exp 된 dmp 파일을 개발서버에 imp를 진행하는데 해당 schema 계정이 아닌 dump 하기 위해 생성한 계정으로 테이블이 imp 되어 기본 exp, imp 하는 방법에 대해 작성하게 되었다.

EXPORT

Full EXPORT

전체 데이터베이스가 Export 된다. 모든 테이블스페이스, 모든 사용자, 또한 모든 객체, 데이터들이 포함 된다.

exp system/manager file='dumpfile_생성경로/dumpfile_name.dmp' full=y

User EXPORT

사용자 자신이 만든 모든 오브젝트를 그 user가 EXPORT 하는 방법

exp scott/tiger file='dumpfile_생성경로/dumpfile_name.dmp'

비밀번호 특수문자 있을 시

exp userid='scott'/'tiger!^'  file='dumpfile_생성경로/dumpfile_name.dmp'

SYSTEM계정으로 특정 user소유의 오브젝트들을 EXPORT 하는 방법

exp system/manager owner=scott  file='dumpfile_생성경로/dumpfile_name.dmp'

Table EXPORT

SYSTEM계정으로 특정 유저의 table을 EXPORT 하는 예제

  • 다른 계정으로 EXPORT시 table의 user명까지 지정해야 EXPORT가 성공한다.
exp system/manager file='dumpfile_생성경로/dumpfile_name.dmp' tables=(usern_ame.table_name, scott.DEPT)

scott user로 table을 몇 개만 EXPORT하는 예제

  • 자신의 table을 EXPORT 할 때에는 user명을 지정할 필요가 없다.
exp scott/tiger file='dumpfile_생성경로/dumpfile_name.dmp' tables=(EMP, DEPT) log=exp.log

EXPORT 옵션

  • userid/passwd : EXPORT를 실행시키고 있는 username/password 명
  • file : 생성되는 EXPORT 덤프 파일명
  • full : 전체 데이터베이스를 EXPORT 할 것인가의 여부 (Y / N)
  • owner : EXPORT 될 데이터베이스의 소유자 명 [owner=user]
  • tables : EXPORT 될 테이블의 리스트 [tables=(table1, table2,...)]
  • log : EXPORT 실행 과정을 지정된 로그 파일에 저장

IMPORT

전체 데이터베이스가 IMPORT(Full Level Export file을 Import)

imp system/manager file='dumpfile_생성경로/dumpfile_name.dmp' full=y

User Export file을 Import

imp scott/tiger file='dumpfile_생성경로/dumpfile_name.dmp'

User Export file을 다른 계정으로 IMPORT

  • scott 유저의 데이터를 EXPORT 받아 test 유저에게 IMPORT 하는 예시
exp system/manager file='dumpfile_생성경로/dumpfile_name.dmp' owner=scott
imp system/manager file='dumpfile_생성경로/dumpfile_name.dmp' fromuser=scott touser=test

IMPORT 옵션

  • username/password : IMPORT를 실생 시키는 계정의 username/password 명
  • file : IMPORT 될 EXPORT 덤프 파일명
  • show : 파일 내용이 화면에 표시되어야 할 것인가를 나타냄(Y / N)
  • ignore : IMPORT 중 CREATE명령을 실행할 때 만나게 되는 에러들을 무시할 것인지 결정(Y / N)
  • full : FULL엑스포트 덤프 파일이 IMPORT 할 때 사용한다.
  • tables : IMPORT 될 테이블 리스트
  • commit : 배열(배열의 크기는 BUFFER에 의해 설정됩니다.) 단위로 COMMIT을 할 것인가 결정 기본적으로는 테이블 단위로 COMMIT을 한다.
  • fromuser : EXPORT덤프 파일로 부터 읽혀야 하는 객체들을 갖고 있는 데이터베이스 계정
  • touser : EXPORT덤프 안에 있는 객체들이 IMPORT 될 데이터베이스 계정

참고

https://godlvkhj.tistory.com/215

http://www.gurubee.net/lecture/1161

728x90

'Oracle > 오라클 이관' 카테고리의 다른 글

exp한 파일 impdp로 import하면 발생되는 오류  (0) 2023.04.20
728x90

Tablespace란?

하나 또는 여러 개의 데이터 파일로 구성되어 있는 논리적인 데이터 저장구조이다.

DataFile이란?

DB Table의 데이터가 물리적으로 저장되는 공간이다. (Data File 1개의 최대 용량 32GB) Tablespace는 1개 이상의 DataFile로 구성되어 있다.

DataFile 확장 방법

  1. DataFile 추가
  2. AUTOEXTEND로 추가
  3. RESIZE

Tablespace 용량 확인 쿼리문

SELECT    A.TABLESPACE_NAME AS "테이블스페이스명",
          A.FILE_NAME AS "파일경로",
          A.BYTES/1024/1024/1024 AS "총크기",
          (A.BYTES - B.FREE)/1024/1024/1024 AS "사용공간",
          B.FREE/1024/1024/1024 AS "여유 공간",
          TO_CHAR( (B.FREE / A.BYTES * 100) , '999.99')||'%' AS "여유공간"
FROM
(
 SELECT FILE_ID,
        TABLESPACE_NAME,
        FILE_NAME,
        SUBSTR(FILE_NAME,1,200) AS FILE_NM,
        SUM(BYTES) BYTES
   FROM DBA_DATA_FILES
 GROUP BY FILE_ID,TABLESPACE_NAME,FILE_NAME,SUBSTR(FILE_NAME,1,200)
) A,
(
 SELECT TABLESPACE_NAME,
        FILE_ID,
        SUM(NVL(BYTES,0)) AS FREE
   FROM DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME,FILE_ID
) B
WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME
 AND A.FILE_ID = B.FILE_ID
ORDER BY A.TABLESPACE_NAME;

Tablespace 관련 조회 쿼리문

select * from dba_tablespaces;
  • 설정된 테이블 스페이스 확인
SELECT * FROM dba_data_files;
  • 데이터가 저장되는 물리경로 및 테이블스페이스 정보
SELECT * FROM user_users;
  • 현재 유저의 default_tablespace 확인

Tablespace 생성

create tablespace [TABLESPACENAME]
datafile '파일경로' size 10M 
autoextend on next 10M 
maxsize 100M 
uniform size 1M 
  • datafile '파일경로' size 10M : 초기 데이터 파일 경로와 크기 설정
  • autoextend on next 10M : 초기 설정한 크기를 모두 사용하는 경우 자동으로 파일의 크기가 정해진 크기만큼 커지는 기능
  • maxsize 100M : 데이터파일이 최대로 커질 수 있는 크기 지정, 기본값 = unlimited
  • uniform size 1M : EXTENT 한 개의 크기를 설정

Tablespace에 Data File 추가하는 방법

1. DataFile 추가
ALTER TABLESPACE [TABLE_SPACE_NAME] ADD DATAFILE [DATA_FILE_NAME] SIZE [SIZE];
2. DataFile 추가 후 Auto Extensible 설정
ALTER TABLESPACE [TABLE_SPACE_NAME] ADD DATAFILE [DATA_FILE_NAME] SIZE [초기추가용량] 
AUTUEXTEND ON NEXT [자동증가 용량] MAXSIZE [최대 용량]

Tablespace 변경 관련 쿼리문

ALTER USER [USER_NAME] DEFAULT TABLESPACE [TABLE_SPACE_NAME];
  • 유저의 default Tablespace 변경
ALTER TABLE [TABLE_NAME] move tablespace [TABLE_SPACE_NAME];
  • 테이블의 Tablespace 변경
ALTER TABLESPACE RENAME A TO B
  • Tablespace 물리적인 파일의 이름 또는 위치변경
ALTER DATABASE MOVE DATAFILE '/원본 경로/파일 이름' TO '/이동 경로/파일 이름';
  • Tablespace Online dbf 파일 위치 이동
DROP TABLESPACE [TABLE_SPACE_NAME] include contents;
  • 테이블스페이스 내 객체(테이블, 인덱스 등)를 모두 삭제
DROP TABLESPACE [TABLE_SPACE_NAME] INCLUDING contents;
  • 테이블스페이스의 모든 세그먼트를 삭제 (데이터가 테이블스페이스는 삭제할 수 없다)
DROP TABLESPACE [TABLE_SPACE_NAME] CASCADE constranints;
  • 삭제된 테이블스페이스 내의 테이블의 기본키와 PK를 참조하는 다른 테이블스페이스의 테이블로부터 참조무결성 제약 조건을 삭제한다.
DROP TABLESPACE [TABLE_SPACE_NAME] INCLUDING CONTENTS AND DATAFILES;
  • 테이블 스페이스의 물리파일까지 삭제

유저 생성시 Tablespace 지정

CREATE USER [USER_NAME] IDENTIFIED BY [PASSWORD]
DEFAULT TABLESPACE [TABLESPACE_NAME]
TEMPORARY TABLESPACE [TABLESPACE_NAME];
  • 기본(디폴트) 테이블스페이스, 임시(temp) 테이블스페이스를 명시해 줄 수 있다.
  • 기본 테이블스페이스란 해당 사용자로 로그인한 뒤 테이블과 같은 각종 데이터베이스 객체가 저장되는 테이블스페이스이다.
  • 임시 테이블스페이스는 해당 사용자가 사용하는 디폴트 임시 테이블스페이스를 말한다.

실수로 dbf 파일을 삭제해버렸다면

shutdown immediate 시 테이블 스페이스를 찾을 수 없다고 에러가 난다.

해결 방법 1

테이블스페이스 오프라인 드롭을 하자

alter database datafile 'file path' offline drop;

해결 방법 2

1. shutdown abort 로 강제 종료
2. startup nomount;
3. alter database mount;
4. alter database datafile 'file path' offline
→ control 파일 정보에 해당 dbf 파일 offline 상태 알려준다.
5. alter database open;

참고

https://m.blog.naver.com/PostView.naver?isHttpsRedirect=true&blogId=tawoo0&logNo=221547724506

https://coding-factory.tistory.com/411

https://itkevin.tistory.com/36

https://yoo-hyeok.tistory.com/136

https://dreamingnote.tistory.com/entry/RESIZE로-TABLESPACE의-data-file-크기-변경

http://bluehb.egloos.com/m/1507700

728x90
728x90

1. 오라클 종료

# 권한 : oracle1
# OS
1. (2호기) 오라클 SYS계정 로그인
sqlplus "/ as sysdba"
	# sqlplus
	1. 오라클 정지 
	shutdown immediate;
    
	2. SQLPLUS 종료
	exit;

# OS
2. (1호기) 오라클 SYS계정 로그인
sqlplus "/ as sysdba"
	# sqlplus
	1. 오라클 정지 
	shutdown immediate;
    
	2. SQLPLUS 종료
	exit;

2. RAC CRS 정지 OS 재기동

# 권한 : root
# OS
1. (2호기) 오라클 CRS 정지
crsctl stop crs

2. (2호기) OS 마운트 경로 정지
hastop -local

3. (2호기) OS 재기동
reboot

4. (1호기) 오라클 CRS 정지
crsctl stop crs

5. (1호기) OS 마운트 경로 정지
hastop -local

6. (1호기) OS 재기동
reboot

3. OS 기동 확인 후 CRS 가동

# 권한 : root
# OS
1. (1호기) OS 경로 마운트 
hastart -local

2. (1호기) 오라클 CRS 기동
crsctl start crs

3. (2호기) OS 경로 마운트 
hastart -local

4. (2호기) 오라클 CRS 기동
crsctl start crs

4. 오라클 기동

# 권한 : oracle1
# OS
1. (1호기) SQLPLUS 접속
sqlplus "/ as sysdba"
	# sqlplus
	1. DB 마운트 
	startup mount;
    
	2. DB 마운트 상태 확인(선택)
	select status, database_status from v$instance;
    
	3. 마운트 DB OPEN 
	alter database open;
    
	4. DB 마운트 상태 확인(필수)
	select status, database_status from v$instance;
    
	5. DB 전자지갑 확인(선택)
	SELECT * FROM v$encrytion_wallet;
    
	6. DB 전자지갑 적용
	alter system set ENCRYPTION wallet open identified by "key";
    
	7. DB 전자지갑 확인(필수)
	SELECT * FROM v$encrytion_wallet;
    
2. (2호기) SQLPLUS 접속
sqlplus "/ as sysdba"
	# sqlplus
	1호기와 방법 동일함
728x90
728x90

비교 연산자 ANY(만족하는 값 하나만 있으면 됨)

조건 결과 설명
1000 > ANY (500, 1000, 2000) TRUE ANY 값에 1000 보다 작은 500이 있으므로 TRUE
1000 = ANY (500, 1000, 2000) TRUE ANY 값에 같은 값 1000이 있으므로 TRUE
2000 < ANY (500, 1000, 2000) FALSE ANY 값에 2000 보다 큰 값이 없으므로 FALSE

 

= ANY 하나라도 만족하는 값이 있으면 결과를 리턴 (IN과 동일)
> ANY 값들 중 최소값 보다 크면 결과를 리턴
>= ANY 값들 중 최소값 보다 크거나 같으면 결과를 리턴
< ANY 값들 중 최대값 보다 작으면 결과를 리턴
<= ANY 값들 중 최대값 보다 작거나 같으면 결과를 리턴
<> ANY 모든 값들 중 다른 값만 리턴 (값이 하나일 때만 가능, 사용X)

SOME은 ANY와 이름만 다를 뿐 동일한 기능이다.

ALL

ALL(30, 50)은 30보다 작고 50보다 작아야 한다. 두 개의 값을 모두 만족해야 함

IN, NOT IN, EXISTS, NOT EXISTS

IN에서 Null은 포함되지 않는다. IS Null로 비교해야 한다.

NOT IN의 경우 조회를 할 때 값이 없으면 ROW가 나와야 할 것 같지만 Null 값이 하나라도 포함되어 있으면 Null을 비교하면서 NOT IN 조건 전체가 false가 되어버려 아무 ROW가 나오지 않는다.

EXISTS는 존재하느냐 존재하지 않느냐의 여부만 체크하기 때문에 서브쿼리의 SELECT 리스트에는 등장하는 값과는 상관없이 서브쿼리의 결과로 반환되는 로우가 있느냐 없느냐만 중요한 것이다. 따라서 IN과 EXISTS는 동일한 결괏값을 출력한다. 반면 NOT IN과 NOT EXISTS는 결괏값이 다를 수 있다.

데이터 모델링

  1. 논리 모델링의 외래키는 물리 모델에서 반드시 구현되지 않는다.
  2. 실제 데이터 베이스 구축 시 참고되는 모델은 물리적 데이터 모델링이다.
  3. 개념 모델링에서 물리 모델링으로 가면서 더 구체적이며 개념 모델링이 가장 추상적이다.
  4. 물리 → 논리 → 개념 갈수록 추상적
  5. 데이터 모델링의 3가지 요소는 Thing, Attirbutes, Relationship이다.

개념적 데이터 모델링

추상화 수준이 높고 업무중심적이고 포괄적인 수준의 모델링 진행 전사적 데이터 모델링, EA 수립 시 많이 이용됨

엔터티, 인스턴스, 속성, 속성 값

  1. 하나의 속성은 하나의 속성값을 가지며 하나 이상의 속성값을 가지는 경우 정규화가 필요함
  2. 한 개의 엔터티는 두 개 이상의 인스턴스의 집합이어야 한다.
  3. 한 개의 엔터티는 두 개 이상의 속성을 갖는다.
  4. 하나의 엔터티의 인스턴스는 다른 엔터티의 인스턴스 간의 관계인 Paring을 가진다.

function(3.46) 함수 결과 값 다른 경우

  • FLOOR : 숫자보다 작거나 같은 최대 정수를 리턴 → 3
  • CEIL/CEILING : 숫자보다 크거나 같은 최소 정수를 리턴 → 4
  • TRUNC : 숫자를 소수 m 자리에서 잘라서 리턴 (m default : 0) → 3
  • ROUND : 숫자를 소수 m 자리에서 반올림하여 리턴 (m default : 0) → 3

정규화

1차 정규형

  • 모든 속성은 반드시 하나의 값을 가져야 한다. 즉, 반복 형태가 있어서는 안 된다.
  • 각 속성의 모든 값은 동일한 형식이어야 한다.
  • 각 속성들은 유일한 이름을 가져야 한다.
  • 레코드들은 서로 간에 식별 가능해야 한다.

2차 정규형

  • 식별자가 아닌 모든 속성들은 식별자 전체 속성에 완전 종속되어야 한다.
  • 이것을 물리 데이터 모델의 테이블로 말하면 기본키가 아닌 모든 칼럼들이 기본키에 종속적이어야 2차 정규형을 만족할 수 있다는 것이다

3차 정규형

  • 2차 정규형을 만족하고 식별자를 제외한 나머지 속성들 간의 종속이 존재하면 안 된다.
  • 이것이 3차 정규형을 만족하는 것이다.

ROLLUP

ROLLUP구문은 GROUP BY 절과 같이 사용되며, GROUP BY절에 의해서 그룹 지어진 집합 결과에 대해서 좀 더 상세한 정보를 반환하는 기능을 수행한다.

SELECT절에 ROLLUP을 사용함으로써 보통의 SELECT 된 데이터와 그 데이터의 총계를 구할 수 있다.

CUBE

SQL> SELECT b.dname, a.job, SUM(a.sal) sal, COUNT(a.empno) emp_count
     FROM emp a, dept b
     WHERE a.deptno = b.deptno
     GROUP BY CUBE(b.dname, a.job)

DNAME      JOB               SAL  EMP_COUNT
---------- ---------- ---------- ----------
ACCOUNTING  CLERK            1300          1
ACCOUNTING  MANAGER          2450          1
ACCOUNTING  PRESIDENT        5000          1
ACCOUNTING                   8750          3 --> ACCOUNTING 부서의 직업별 급여의 총계와 사원 수.
RESEARCH    ANALYST          6000          2
RESEARCH    CLERK            1900          2
RESEARCH    MANAGER          2975          1
RESEARCH                    10875          5 --> RESEARCH 부서의 직업별 급여의 총계와 사원 수.
SALES       MANAGER         28500          1
SALES       SALESMAN         4000          3
SALES                       32500          4 --> SALES 부서의 직업별 급여 총계와 사원수.
            ANALYST          6000          2
            CLERK            3200          3
            MANAGER         33925          3
            PRESIDENT        5000          1
            SALESMAN         4000          3
                            52125         12  --> 직업별로 급여의  총계와 사원 수.
  • CUBE는 Cross-Tab에 대한 Summary를 추출하는 데 사용된다
  • 즉 ROLLUP에 의해 나타 내어지는 Item Total값과 Column Total값을 나타 낼 수 있다.

Grouping 함수

: pseudo column (의사컬럼 : 실제로는 존재하지 않으나 특수목적으로 사용)

GROUPING 함수는 ROLLUP, CUBE에 모두 사용할 수 있다.

GROUPING 함수는 해당 Row가 GROUP BY에 의해서 산출된 Row인 경우에는 0을 반환하고, ROLLUP이나 CUBE에 의해서 산출된 Row인 경우에는 1을 반환하게 된다.

따라서 해당 Row가 결과집합에 의해 산출된 Data 인지, ROLLUP이나 CUBE에 의해서 산출된 Data 인지를 알 수 있도록 지원하는 함수이다.

GROUP BY ROLLUP(DNAME,JOB)  
 = GROUP BY DNAME,JOB
	UNION ALL
	GROUP BY DNAME
	UNION ALL
	모든 집합 그룹 결과

GROUP BY GROUPING SET(DNAME,JOB)
= GROUP BY DNAME
	UNION ALL
	GROUP BY JOB

GROUP BY CUBE(DNAME,JOB)
 = GROUP BY DNAME,JOB
	UNION ALL
	GROUP BY DNAME
	UNION ALL
	GROUP BY JOB
	UNION ALL
	모든 집합 그룹 결과

ANSI SQL JOIN

ANSI SQL에서 조인 조건절(ON 절)에 사용된 조건절은 조인 전 조건으로 작용한다. ON 절 이후 WHERE 절에서 쓰인 조건절은 조인 후 조건절로 사용된다.

조인 조건과 조회 조건이 분리되어야 하므로 조회 조건은 WHERE 절로 분리되어야 함

SQL Server vs Oracle

SQL SERVER의 IDENTITY로 지정된 칼럼에는 값을 넣으면 에러가 남 ORACLE의 CHECK 조건을 만족하지 못할 경우 에러가 나나 NULL 은 무시됨(Null Row Insert 가능)

Hash Join

  1. Hash Join 은 Non Equal Join 은 불가능함. Equal Join 만 가능함
  2. 사전 Sorting 작업이 필요한 Join 알고리즘은 Sort Merge Join 임
  3. 각 테이블에 인덱스가 반드시 필요한 것은 아니다.
  4. 일반적으로 작은 테이블을 Memory에 올리는 선행 테이블로 사용한다.

SQL 수행 순서

FROM → WHERE → GROUP BY → HAVING → SELECT → ORDER BY

문자 비교

SAPCE를 추가하여 길이를 맞춰 비교하는 방법은 CHAR 타입인 경우임

SQL 결합 함수

Oracle의 결합 함수 : CONCAT, /, ||

SQL Server : +

SQL Server TOP vs Oracle Rownum

TOP (Expression) [PERCENT] [WITH TIES]

  • WITH TIES : ORDER BY 조건 기준으로 TOP N의 마지막 행으로 표시되는 추가 행의 데이터가 같을 경우 N + 동일 정렬 순서 데이터를 추가 반환하도록 지정하는 옵션 (마지막 기준 공통일 경우 모두 출력)

ROWNUM < 4의 의미는 3건까지 출력이므로 TOP(3) 임 WITH TIES를 사용할 경우 동일 데이터가 있을 때 추가 건수가 출력되는 현상이 가능함

ANSI Join SQL

NATURAL JOIN에서 사용된 열은 식별자를 가질 수 없음. 즉 EMP.DEPTNO 와 같이 OWNER 명을 사용하면 에러가 난다.

엔터티 기준

  • 엔터티는 사람, 장소, 물건, 사건, 개념 등의 명사에 해당한다.
  • 엔터티는 업무상 관리가 필요한 관심사에 해당한다.
  • 엔터티는 저장이 되기 위한 어떤 것(Thing)이다.

계층형 SQL

  • CONNECT_BY_ISLEAF : 전개 과정에서 해당 데이터가 리프 데이터면 1, 아니면 0
  • CONNECT_BY_ISCYCLE : 전개 과정에서 자식을 갖는데, 해당 데이터가 조상으로 존재하면 1, 그렇지 않으면 0 여기서 조상이란 자신으로부터 루트까지의 경록에 존재하는 데이터를 말함
  • SYS_CONNECT_BY_PATH : 하위 레벨의 칼럼까지 모두 표시해 줌 (구분자 지정 가능)
  • CONNECT_BY_ROOT : Root 노드의 정보를 표시

RANGE BETWEEN start_point AND end_point

  • start_point는 end_point와 같거나 작은 값이 들어감
  • Default값은 RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
  • UNBOUNDED PRECEDING : start_point만 들어갈 수 있으며, 파티션의 first row
  • UNBOUNDED FOLLOWING : end_point만 들어갈 수 있으며, 파티션의 last row
  • CURRENT ROW : start, end_point 둘 다 가능. 윈도우는 CUREENT ROW에서 start 하거나 end 함

권한

DBA 권한은 SYSTEM, SYS 등의 상위 유저와 그에 해당하는 권한을 가진 경우 부여 가능

테이블의 소유자는 해당 테이블의 DML 권한을 다른 유저에게 부여할 수 있다.

MAX(LEVEL)

계층형 쿼리에서 최대 계층의 수를 구하기 위한 문제. MAX (LEVEL)을 사용하여 최대 계층 수를 구함

NOT EXISTS → OUTER JOIN

NOT EXISTS의 OUTER JOIN으로의 변형을 묻는 문제로 NOT EXISTS는 OUTER JOIN으로 변경 시 NOT NULL COLUMN에 대한 IS NULL 체크로 NOT EXISTS를 구현가능하다

참조

https://gent.tistory.com/287

https://icty.tistory.com/entry/Oracle-EXISTS-연산자의-활용

https://androphil.tistory.com/166

SQLD_예상문제해답

728x90
728x90

테이블 복구는 FLASHBACK을 사용하는 게 편리하고 간단하다. FLASHBACK을 사용하려면 undo_retension 파라미터와 undo 테이블 스페이스의 충분한 공간이 필요하다.

FLASHBACK은 데이터나 테이블이 최근에 삭제되었을 때만 유용하게 사용이 가능하다. 이런 단점을 보안하는 방법이 RMAN을 이용한 복구이다.

RMAN 테이블 단위 복구

RMAN을 이용한 복구는 오래된 데이터나 테이블을 삭제했을 때 유용하게 사용한다.

  1. Auxiliary DB(보조 DB) 생성 및 시점 복구
  2. 테이블 Datapump Export Auxiliary DB
  3. 테이블 Datapump Import STR DB

RMAN을 테이블을 복구하기 위해 Auxiliary DB를 따로 만들어야 되기 때문에 운영시스템의 CPU, 메모리, 디스크 공간을 많이 사용해서 정말 필요한 상황이 아니면 테스트 DB를 따로 만들어서 거기에 복구하고 데이터를 옮기는 게 실무에서는 더 적절하다.

RMAN 테이블 복구 제약조건

  1. SYS 계정 테이블 복구 불가
  2. SYSTEM 테이블 복구 불가
  3. SYSAUX 테이블 복구 불가
  4. 테이블 NOT NULL 제약 조건 복구 불가(REMAP)

NLS_DATE_FORMAT 변경

export NLS_DATE_FORMAT="YYYY/MM/DD(DY) HH24:MI:SS"

rman_backup.rcv 백업 파일 생성

cat << EOF > /home/oracle/script/rman_backup.rcv
run {
  allocate channel ch1 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch2 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch3 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch4 device type disk format '/RMANBKP/str_%T_full_%U';
  crosscheck archivelog all;
  delete noprompt archivelog all completed before 'trunc(sysdate) -1';
  backup as compressed backupset database tag 'DB_FULL_BACKUP' plus archivelog tag 'ARCHIVELOG';
  backup current controlfile tag 'CONTROLFILE' format '/RMANBKP/str_%T_cont_%U';
  backup spfile tag 'SPFILE' format '/RMANBKP/str_%T_para_%U';
  crosscheck backup;
  delete noprompt backup completed before 'trunc(sysdate) -1';
  release channel ch1;
  release channel ch2;
  release channel ch3;
  release channel ch4;
}

run {
begin
for i in 1..10 loop
  EXECUTE IMMEDIATE 'ALTER SYSTEM SWITCH LOGFILE';
end loop;
end;
/
}
EOF

백업 실행

rman target /

@/home/oracle/script/rman_backup.rcv

list backup summary;

DB 테이블 복구

-- DB 시간 확인(복구 시간 확인)
SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS') AS "RECO_TIME" FROM DUAL;
-- <<DB 시간 확인(복구 시간 확인)>>을 확인하고 until time 뒤에 시간을 넣어주세요.
rman target /

-- PARALLEL 4 변경
CONFIGURE DEVICE TYPE DISK PARALLELISM 4;

-- RMAN TABLE 복구
recover table STR."TEST" until time "TO_DATE('2023/01/12 12:53:47','YYYY/MM/DD HH24:MI:SS')" auxiliary  destination  '/RMANBKP'
datapump destination '/RMANBKP' dump file 'TEST_20230112.dmp';

RMAN TABLE RENAME 복구

recover table STR."TEST" until time "TO_DATE('2023/01/12 12:53:47','YYYY/MM/DD HH24:MI:SS')" auxiliary  destination  '/RMANBKP'
remap TABLE 'STR'.'TEST':'TEST_20230112_1253'
datapump destination '/RMANBKP' dump file 'TEST_20230112.dmp';

-- PARALLEL 초기화
CONFIGURE DEVICE TYPE DISK CLEAR;

PITR 관련 로그 파일 삭제

## Linux oracle 계정 실행
find /RMANBKP \\( -name "*PITR_STR*" -o -name "STR" \\) | xargs rm -rf
find $ORACLE_BASE/admin -name "*pitr_STR" | xargs rm -rf
find $ORACLE_BASE/diag/rdbms -name "*pitr_str" | xargs rm -rf
find $ORACLE_HOME/dbs \\( -name "hc*dat" -o -name "spfile*ora" -o -name "*PITR_STR" \\) -not \\( -name "hc_STR.dat" -o -name "spfileSTR.ora" \\) | xargs rm -f

## 삭제 확인
find $ORACLE_BASE \\( -name "*pitr_str*" -o -name "*pitr_STR*" -o -name "*PITR_STR" \\)

crontab 자동 백업 삭제

crontab -r

참조

https://www.youtube.com/watch?v=5f8H6c1u3-w&t=603s 

 

728x90
728x90

RMAN 데이터 파일 복구 명령어 순서

  1. DB SHUTDOWN
  2. STARTUP MOUNT
  3. RESTORE DATAFILE
  4. RECOVER DATAFILE
  5. DB OPEN

RMAN 전체 복구 명령어 순서

  1. DB SHUTDOWN
  2. STARTUP NOMOUNT
  3. RESTORE CONTROLFILE
  4. STARTUP MOUNT
  5. RESTORE DATABASE
  6. RECOVER DATABASE
  7. DB OPEN RESETLOGS

전체 백업

-- 전체 백업 파일
rman target /

list backup summary;

## 아카이브 로그 파일 확인
ls -l /ARC_STR

## 아카이브 로그 파일 생성
## ALTER SYSTEM SWITCH LOGFILE 10회 수행
sqlplus / as sysdba <<EOF
begin
for i in 1..10 loop
  EXECUTE IMMEDIATE 'ALTER SYSTEM SWITCH LOGFILE';
end loop;
end;
/
exit
EOF

데이터 파일 복구

## 리스너 종료
lsnrctl stop 

-- DB 접속
sqlplus / as sysdba

-- DB 종료
shutdown abort

startup mount

-- rman 접속
rman target /

REPORT SCHEMA;

RESTORE DATAFILE 3,5;
RECOVER DATAFILE 3,5;

ALTER DATABASE OPEN

REPORT SCHEMA;

## sysaux 데이터 파일 확인
## linux 수행
ls -lh /oracle/app/oracle/oradata/STR

DB 전체 복구

sqlplus / as sysdba

shutdown abort
startup nomount

-- rman 접속
-- /RMANBKP/str_20230108_cont_541hdsi2_1_1 --> 최근 백업한 컨트롤 파일로 변경해주세요.

rman target /

host 'ls -l /RMANBKP/str*cont*';

RESTORE CONTROLFILE FROM '/RMANBKP/str_20230108_cont_541hdsi2_1_1';

host 'ls -l /oracle/app/oracle/oradata/STR';

ALTER DATABASE MOUNT;

CONFIGURE DEVICE TYPE DISK PARALLELISM 4;

RESTORE DATABASE;
RECOVER DATABASE;
host 'ls -l /ARC_STR';

ALTER DATABASE OPEN RESETLOGS;

-- 정상적으로 백업 되었는지 확인
REPORT SCHEMA;

CONFIGURE DEVICE TYPE DISK CLEAR;

## 리스너 시작
lsnrctl start

리스너 빠르게 등록하는 팁

lsnrctl start 명령어 후 SQLPlus에 접속하여 alter system register

참고

https://www.youtube.com/watch?v=BTd-wVIjZI8&t=627s 

 

728x90
728x90

RMAN(Recovery Manager)?

오라클에서 제공하는 백업, 복구 유틸리티이다. 예전에는 Begin End 백업을 많이 사용했지만, 요즘 회사 중요 메인 시스템의 경우 오라클을 RAC의 ASM을 많이 사용하는 추세라 RMAN을 이용한 백업은 필수가 되어가고 있다.

RMAN의 이점

  1. 성능
    1. 백업을 parallel로 병렬 처리가 가능하다.
  2. 압축
    1. 백업 압축률을 설정해 중복된 데이터가 많다면 백업 용량을 줄일 수 있다.
    2. 기본 압축 옵션은 basic이다.
  3. 증분 백업
    1. db의 데이터가 50에서 100 테라가 넘는다면 Incremental 백업을 이용해 하루에 증가되는 데이터만 백업할 수 있다.
  4. 암호화
    1. 암호화를 해서 백업이 가능하다.

백업하는 내용

  1. Data File
  2. Control File
  3. Parameter File
  4. Archived Redo log

백업 계획

  • 1주일에 한번 월요일에 Full Backup 화수목금토일 Incremental Backup을 한다.
  • 스토리지 공간이 넉넉하다면 매일 Full Backup을 하는 것을 추천한다.
  • 백업 성능을 좋게 하려면 디스크 I/O 성능이 좋은 스토리지가 필요하다.

RMAN 실습

  1. 디렉터리 생성 /ARC_STR, /RMANBKP
  2. Archive 모드 변경
  3. RMAN 백업
  4. 백업 자동화

1. 아카이브 & RMAN BACKUP 디렉터리 생성(root 계정)

## 아카이브 디렉터리 생성
mkdir /ARC_STR
chown oracle.dba /ARC_STR

## RMAN BACKUP 디렉터리 생성
mkdir -p /RMANBKP/control
chown -R oracle.dba /RMANBKP

ls -ld /RMANBKP /ARC_STR

2. 디스크 읽기 성능 테스트

fdisk -l | grep 'Disk /dev/sd'
hdparm -t /dev/sda

3. 아키이브 로그 파라미터 변경, 아카이브 로그 모드 변경

ALTER SYSTEM SET log_archive_dest='/ARC_STR' SCOPE=SPFILE;
ALTER SYSTEM SET log_archive_format='ARCH_STR_%r_%t_%s.ARC' SCOPE=SPFILE;

-- 아카이브 로그 모드 변경
shutdown immediate;
startup mount;
alter database archivelog;

archive log list;
alter database open;

4. RMAN 접속, DB 전체 정보, DB 파일 상태 점검

-- rman 접속
rman target /

-- DB 전체 정보
report schema;

-- DB 파일 상태 점검
validate database;

validate database는 데이터베이스 안에 있는 블록들에 손상된 블록이 있는지 확인하는 방법이다.

5. RMAN 백업 설정

-- 2일 전의 백업까지 
rman target /

CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 2 DAYS;
CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/RMANBKP/control/control_%F';
CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/RMANBKP/control/snapcontrol_STR.f';

-- rman 설정 원복
CONFIGURE RETENTION POLICY CLEAR;
CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK CLEAR;
CONFIGURE SNAPSHOT CONTROLFILE NAME CLEAR;

-- rman 설정 확인
show all;

6. RMAN 백업

-- %T (YYYYMMDD) 년월일 포멧
-- %U 시스템 생성 고유 파일 이름 8자리
-- 전체 백업
backup database format '/RMANBKP/STRDB2_full_n_bkp_%T_%U';

-- 전체 백업 + 압축
backup as compressed backupset database format '/RMANBKP/STRDB2_full_c_bkp_%T_%U';

-- 백업 상태 확인
list backup;
list backup summary;

host 'ls -lh /RMANBKP';

7. ARCHIVE LOG & BACKUP 삭제(rman에서 수행)

run {
  delete noprompt archivelog all;
  delete noprompt backup;
}

8. channel 4개로 Parallel 백업(rman에서 수행)

run {
  allocate channel ch1 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch2 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch3 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch4 device type disk format '/RMANBKP/str_%T_full_%U';
  crosscheck archivelog all;
  delete noprompt archivelog all completed before 'trunc(sysdate) -1';
  backup as compressed backupset database tag 'DB_FULL_BACKUP' plus archivelog tag 'ARCHIVELOG';
  backup current controlfile tag 'CONTROLFILE' format '/RMANBKP/str_%T_cont_%U';
  backup spfile tag 'SPFILE' format '/RMANBKP/str_%T_para_%U';
  crosscheck backup;
  delete noprompt backup completed before 'trunc(sysdate) -1';
  release channel ch1;
  release channel ch2;
  release channel ch3;
  release channel ch4;
}

9. Linux Shell을 이용한 DB 전체 자동백업과 삭제 스크립트

## rman 백업 로그 디렉터리 생성
## oracle 계정
cd /home/oracle
mkdir -p /home/oracle/oraclelog

## rman 백업 스크립트 디렉터리 생성
## oracle 계정
mkdir -p /home/oracle/script

## 임시 nfsbackup 디렉터리 생성
## root 계정
mkdir /nfsbackup
chown oracle.dba /nfsbackup
ls -ld /nfsbackup

nfsbackup는 실제 운영에서는 백업 서버를 연결해서 원격 디렉터리를 만들지만 테스트할 때는 백업 서버가 없으니 있다고 가정하고 실행한다.

10. rman 백업 Shell 스크립트 생성(vi 편집기 사용 안하고 파일 만드는 법)

-- Channel을 많이 사용하면 DB 전체 SQL 성능 지연 발생할수 있으니 주의 필요!!!
cat << \\FILE > /home/oracle/script/rman_backup.sh
#!/bin/bash

################################################################################
#  RMAN FULL BACKUP SCRIPT
#    V 1.0    CPU 8Core 권장 스크립트 (Channel 4개 사용)  DBBODA
#                  Channel을 많이 사용하면 DB 전체 SQL 성능 지연 발생할수 있으니 주의 필요!!!
################################################################################
export ORACLE_HOME=/oracle/app/oracle/product/19.0.0.0/db_1
export ORACLE_SID=STR
export PATH=$ORACLE_HOME/bin:$PATH
export DATE=`date +%Y%m%d`
export YDATE=`date -d '1 day ago' '+%Y%m%d'`
export HOSTNAME=`hostname`
export NLS_DATE_FORMAT="YYYY/MM/DD(DY) HH24:MI:SS"

rman log=/home/oracle/oraclelog/${HOSTNAME}_rman_backup_${DATE}.log << EOF
connect target /
run {
  allocate channel ch1 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch2 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch3 device type disk format '/RMANBKP/str_%T_full_%U';
  allocate channel ch4 device type disk format '/RMANBKP/str_%T_full_%U';
  crosscheck archivelog all;
  delete noprompt archivelog all completed before 'trunc(sysdate) -1';
  backup as compressed backupset database tag 'DB_FULL_BACKUP' plus archivelog tag 'ARCHIVELOG';
  backup current controlfile tag 'CONTROLFILE' format '/RMANBKP/str_%T_cont_%U';
  backup spfile tag 'SPFILE' format '/RMANBKP/str_%T_para_%U';
  crosscheck backup;
  delete noprompt backup completed before 'trunc(sysdate) -1';
  release channel ch1;
  release channel ch2;
  release channel ch3;
  release channel ch4;
}
exit
EOF

## RMAN Backup zip
cd /RMANBKP
zip -r str_full_backup_${YDATE}.zip str_${YDATE}* control/

## Archive zip
cd /ARC_STR
export ARCHFILE=`ls -l --time-style="+%Y%m%d" | grep ${YDATE} | awk '{print $7}'`
zip ${HOSTNAME}_arc_backup_${YDATE}.zip ${ARCHFILE}

## NFS Backup
cp /RMANBKP/str_full_backup_${YDATE}.zip /nfsbackup/str_full_backup_${YDATE}.zip
cp /ARC_STR/${HOSTNAME}_arc_backup_${YDATE}.zip /nfsbackup/${HOSTNAME}_arc_backup_${YDATE}.zip

## Remove zip 
rm -f /RMANBKP/str_full_backup_${YDATE}.zip
rm -f /ARC_STR/${HOSTNAME}_arc_backup_${YDATE}.zip

## Remove nfs Backup file
export WDATE=`date -d '8 day ago' '+%Y%m%d'`
find /nfsbackup/ -name "*${WDATE}.zip" -exec rm -f {} \\;

FILE

RMAN Backup zip은 변수 값으로 압축하고 Archive zip도 동일하게 압축한다. NFS 디렉터리에서 전체 백업한 압축 파일, 아카이브 로그 압축 파일을 cp로 복사하고 rm 명령으로 RMAN 백업 디렉터리와 아카이브 디렉터리 zip 압축 파일을 삭제한다. 추가로 nfs 백업 디렉터리의 8일 전 파일을 자동으로 삭제하게 만들었다.

11. shell 스크립트 권한 변경, crontab 추가

## shell 스크립트 권한 변경
## oracle 계정
cd /home/oracle/script
chmod 755 rman_backup.sh

--crontab 추가
crontab -e
## RMAN FULL BACKUP
00 02 * * * /home/oracle/script/rman_backup.sh

참고

https://www.youtube.com/watch?v=PA9VIjbYd4w&t=901s 

 

728x90

+ Recent posts