posted by I유령I 2010. 3. 5. 03:34

posted by I유령I 2010. 3. 5. 03:31

'Oracle 10g > 10g - Admin I' 카테고리의 다른 글

Backup  (0) 2010.03.08
sysdba 권한 로그인시 패스워드 지정  (0) 2010.03.05
Constraints (제약 조건)  (0) 2010.03.05
Index (인덱스)  (0) 2010.03.05
Table (테이블)  (0) 2010.03.03
posted by I유령I 2010. 3. 5. 03:30
■ 제약조건 테스트

[oracle@ghost]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.1.0 - Production on Fri Mar 5 02:12:40 2010

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

Connected to an idle instance.

SQL> startup
ORACLE instance started.

Total System Global Area  285212672 bytes
Fixed Size                  1218992 bytes
Variable Size              92276304 bytes
Database Buffers          188743680 bytes
Redo Buffers                2973696 bytes
Database mounted.
Database opened.
SQL> conn hr/hr
Connected.
SQL> create table testing(no number(5) check (no in (10, 20, 30))
  2  deferrable initially deferred);

Table created.

#commit 시 제약조건 검사
SQL> alter session set constraint = deferred;

Session altered.

SQL> insert into testing values(100);

1 row created.

SQL> insert into testing values(20);

1 row created.

SQL> commit;
commit
*
ERROR at line 1:
ORA-02091: transaction rolled back
ORA-02290: check constraint (HR.SYS_C005393) violated


SQL> select * from testing;

no rows selected

#DML 작업시 제약조건 즉시 검사
SQL> alter session set constraint = immediate;

Session altered.

SQL> insert into testing values(100);
insert into testing values(100)
*
ERROR at line 1:
ORA-02290: check constraint (HR.SYS_C005393) violated


SQL> insert into testing values(10);

1 row created.

SQL> commit;

Commit complete.

SQL> 



■ 제약조건 활성화 / 비활성화 테스트
SQL> desc user_constraints;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 OWNER                                                                                                NOT NULL VARCHAR2(30)
 CONSTRAINT_NAME                                                                                      NOT NULL VARCHAR2(30)
 CONSTRAINT_TYPE                                                                                       VARCHAR2(1)
 TABLE_NAME                                                                                           NOT NULL VARCHAR2(30)
 SEARCH_CONDITION                                                                                      LONG
 R_OWNER                                                                                               VARCHAR2(30)
 R_CONSTRAINT_NAME                                                                                     VARCHAR2(30)
 DELETE_RULE                                                                                           VARCHAR2(9)
 STATUS                                                                                                VARCHAR2(8)
 DEFERRABLE                                                                                            VARCHAR2(14)
 DEFERRED                                                                                              VARCHAR2(9)
 VALIDATED                                                                                             VARCHAR2(13)
 GENERATED                                                                                             VARCHAR2(14)
 BAD                                                                                                   VARCHAR2(3)
 RELY                                                                                                  VARCHAR2(4)
 LAST_CHANGE                                                                                           DATE
 INDEX_OWNER                                                                                           VARCHAR2(30)
 INDEX_NAME                                                                                            VARCHAR2(30)
 INVALID                                                                                               VARCHAR2(7)
 VIEW_RELATED                                                                                          VARCHAR2(14)

SQL> col search_condition format a50;
SQL> select constraint_name, search_condition from user_constraints
  2  where table_name = 'TESTING';

CONSTRAINT_NAME                SEARCH_CONDITION
------------------------------ --------------------------------------------------
SYS_C005393                    no in (10, 20, 30)

#제약조건 비활성화
SQL> alter table testing modify constraint SYS_C005393 disable;

Table altered.

#제약조건 no in (10, 20, 30)에 만족하지 않지만 비활성화 상태이기 때문에 DML이 가능하다.
SQL> insert into testing values(50);

1 row created.

SQL> insert into testing values(30);

1 row created.

SQL> commit;

Commit complete.

#제약조건 활성화
SQL> alter table testing modify constraint SYS_C005393 enable novalidate;

Table altered.

#제약조건 no in (10, 20, 30)이 활성화 상태이기 때문에 DML 작업시 에러가 발생한다.
SQL> insert into testing values(50);
insert into testing values(50)
*
ERROR at line 1:
ORA-02290: check constraint (HR.SYS_C005393) violated


SQL> insert into testing values(20);

1 row created.

SQL> commit;

Commit complete.

SQL> 



■ EXCEPTIONS Table 사용법
SQL> @?/rdbms/admin/utlexcpt   

Table created.

SQL> desc exceptions;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 ROW_ID                                                                                                ROWID
 OWNER                                                                                                 VARCHAR2(30)
 TABLE_NAME                                                                                            VARCHAR2(30)
 CONSTRAINT                                                                                            VARCHAR2(30)

SQL> 

'Oracle 10g > 10g - 실습' 카테고리의 다른 글

Profile(프로파일) 생성과 관리  (0) 2010.03.05
User(유저) 생성과 관리  (0) 2010.03.05
Table : Partitioned Table  (0) 2010.03.04
Table : 테이블의 공간 할당과 해제  (0) 2010.03.04
Table : Row Migration과 Chaining  (0) 2010.03.04
posted by I유령I 2010. 3. 5. 03:05
■ Types of Constraints (제약 조건 유형)
NOT NULL : 열에 NULL 값을 포함할 수 없도록 지정
UNIQUE : 열 또는 열 조합을 고유하게 지정
PRIMARY KEY : 열 또는 열 조합을 테이블의 기본 키로 지정
FOREIGN KEY : 열 또는 열 조합을 참조 무결성 제약 조건의 외래키로 지정
CHECK : 테이블의 각 행이 만족해야 하는 조건 지정

NOT NULL 제약 조건은 테이블의 열에 값이 포함되어야 합니다.
UNIQUE 키 제약 조건에서는 하나의 열 또는 여러 열에 있는 값(키)이 고유해야 합니다. 테이블에 있는 어떤 행도 지정된 열 또는 열 집합에서 중복된 값을 가질 수 없습니다.

데이터베이스의 각 테이블은 PRIMARY KEY 제약 조건을 하나까지만 가질 수 있습니다.
PRIMARY KEY 제약 조건은 다음 두 조건을 모두 만족시킵니다.
• 테이블에 있는 어떤 행도 지정된 열에서 중복된 값을 가질 수 없습니다.
• 기본 키 열은 NULL 값을 포함할 수 없습니다.
• 열 또는 열 집합의 CHECK 무결성 제약 조건은 지정된 조건이 참이거나 테이블의 모든 행에 대해 알 수 없음이어야 합니다.


■ Constraint States (제약 조건 상태)
무결성 제약 조건은 활성화(ENABLE)되거나 비활성화(DISABLE)될 수 있습니다.
제약 조건이 활성화되면 데이터베이스에서 데이터가 입력 또는 갱신될 때 검사됩니다.
제약 조건 규칙을 따르지 않는 데이터는 입력할 수 없습니다.
제약 조건이 비활성화되면 규칙을 따르지 않는 데이터를 데이터베이스에 입력할 수 있습니다.
무결성 제약 조건은 다음 상태 중 하나일 수 있습니다.

• DISABLE NOVALIDATE
• DISABLE VALIDATE
• ENABLE NOVALIDATE
• ENABLE VALIDATE

DISABLE NOVALIDATE: 이 제약 조건은 검사하지 않으며 입력 또는 갱신한 새로운 데이터 뿐만 아니라 테이블의 데이터도 해당 제약 조건에서 정의한 규칙을 따르지 않을 수 있습니다.

DISABLE VALIDATE: 제약 조건이 이 상태일 경우에는 제약 조건이 있는 열을 수정할 수 없으며 제약 조건에 대한 인덱스는 삭제되고 제약 조건은 비활성화됩니다.
※ 제약 조건이 Deferrable인 경우에는 인덱스가 삭제되지 않습니다.

ENABLE NOVALIDATE: 제약 조건이 이 상태면 제약 조건을 위반하는 새 데이터를 입력할 수 없지만 테이블에 적합하지 않은 데이터 즉, 제약 조건을 위반하는 데이터를 포함할 수는 있습니다. NOVALIDATE 상태의 제약 조건 활성화는 적합한 OLTP 데이터를 업로드하는 데이터 웨어하우스 구성에 가장 유용합니다.

ENABLE VALIDATE: 제약 조건이 이 상태면 제약 조건을 위반하는 행을 테이블에 삽입할 수 없지만 제약 조건이 비활성화된 동안에는 삽입할 수 있습니다. 이러한 행을 제약 조건의 예외라고 합니다. 제약 조건이 ENABLE NOVALIDATE 상태가 되면 제약 조건이 비활성화된 동안 입력된 데이터가 위반 상태가 됩니다. 제약 조건이 검증된 상태가 되려면 제약 조건을 위반하는 행이 갱신 또는 삭제되어야 합니다.

제약 조건을 Disabled 상태에서 ENABLE VALIDATE로 변경하면 테이블이 잠기고 테이블에 있는 모든 데이터에 대해 일치성이 검사되기 때문에 데이터 로드 같은 DML 작업이 대기할 수 있으므로 먼저 Disabled 상태에서 ENABLE NOVALIDATE로 변경했다가 다시 ENABLE VALIDATE로 변경하는 것이 좋습니다.

이러한 상태 간의 변환은 다음 규칙을 따릅니다.
• NOVALIDATE가 지정되지 않은 경우 ENABLE은 VALIDATE를 의미합니다.
• VALIDATE가 지정되지 않은 경우 DISABLE은 NOVALIDATE를 의미합니다.
• VALIDATE 및 NOVALIDATE는 기본적으로 ENABLE 및 DISABLE 상태를 의미하지 않습니다.
• 고유 키 및 기본 키가 DISABLE 상태에서 ENABLE 상태로 변경되고 기존 인덱스가 없는 경우 고유 인덱스가 자동으로 생성됩니다. 인덱스가 Deferrable 상태인 경우에 는 예외가 있습니다. 마찬가지로 고유 키 및 기본 키가 ENABLE 상태에서 DISABLE 상태로 변경되고 고유 인덱스로 활성화된 경우에는 해당 고유 인덱스가 삭제됩니다.
• 제약 조건이 NOVALIDATE 상태에서 VALIDATE 상태로 변경될 때는 모든 데이터가 검사되어야 하지만 VALIDATE에서 NOVALIDATE로 변경될 경우 데이터가 이미 검사 되었다는 사실이 인식되지 않습니다.
• 단일 제약 조건을 ENABLE NOVALIDATE 상태에서 ENABLE VALIDATE 상태로 변경한 경우에도 읽기, 쓰기 또는 기타 DDL 문을 차단하지 않습니다.


■ Defining Constraints Immediate or Deferred
구문
ALTER SESSION SET CONSTRAINT[S] = { IMMEDIATE | DEFERRED | DEFAULT}
SET CONSTRAINT | CONSTRAINTS { constraint | ALL } { IMMEDIATE | DEFERRED }


■ Defining Constraints While Creating a Table (테이블 생성 중 제약 조건 정의)
예제)
CREATE TABLE hr.employee(
  id NUMBER(7)
    CONSTRAINT employee_id_pk PRIMARY KEY
    DEFERRABLE
    USING INDEX
      STORAGE(INITIAL 100K NEXT 100K)
      TABLESPACE indx,
  last_name VARCHAR2(25)
    CONSTRAINT employee_last_name_nn NOT NULL,
  dept_id NUMBER(7))
TABLESPACE users;


■ Enabling Constraints (제약 조건 활성화)
구문
ALTER TABLE [ schema. ] table
ENABLE NOVALIDATE {CONSTRAINT constraint
| PRIMARY KEY
| UNIQUE ( column [, column ] ... ) }
[ USING INDEX index_clause ]

예제)
ALTER TABLE hr.departments
ENABLE NOVALIDATE CONSTRAINT dept_pk;

구문
ALTER TABLE [ schema. ] table
ENABLE VALIDATE {CONSTRAINT constraint
| PRIMARY KEY
| UNIQUE ( column [, column ] ... ) }
[ USING INDEX index_clause ]
[ EXCEPTIONS INTO [ schema. ] table ]

예제)
ALTER TABLE hr.employees
ENABLE VALIDATE CONSTRAINT emp_dept_fk;


■ Using the EXCEPTIONS Table (EXCEPTIONS 테이블 사용)
• utlexcpt1.sql 스크립트를 실행하여 EXCEPTIONS 테이블 생성
• EXCEPTIONS 옵션을 사용하여 ALTER TABLE 문 실행
• EXCEPTIONS의 하위 질의를 사용하여 부적합한 데이터가 있는 행 찾기
• 오류 수정
• ALTER TABLE을 재실행하여 제약 조건 활성화

예제)
SQL> @?/rdbms/admin/utlexcpt   

Table created.

SQL> desc exceptions;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 ROW_ID                                                                                                ROWID
 OWNER                                                                                                 VARCHAR2(30)
 TABLE_NAME                                                                                            VARCHAR2(30)
 CONSTRAINT                                                                                            VARCHAR2(30)

SQL> 

'Oracle 10g > 10g - Admin I' 카테고리의 다른 글

sysdba 권한 로그인시 패스워드 지정  (0) 2010.03.05
프로파일 & 유저 관리 & 권한 관리  (0) 2010.03.05
Index (인덱스)  (0) 2010.03.05
Table (테이블)  (0) 2010.03.03
Tablespace 관련 명령어  (0) 2010.02.27
posted by I유령I 2010. 3. 5. 01:37

■ Creating Normal B-Tree Indexes (일반 B-Tree 인덱스 생성)
예제)
CREATE INDEX hr.employees_last_name_idx
ON hr.employees(last_name)
PCTFREE 30
STORAGE(INITIAL 200K NEXT 200K
PCTINCREASE 0 MAXEXTENTS 50)
TABLESPACE indx;

※ 일반 B-Tree 인덱스 구문옵션
UNIQUE: 고유 인덱스 지정에 사용. (기본값은 Nonunique)
Schema: 인덱스/테이블 소유자입
Index: 인덱스 이름입
Table: 테이블 이름
Column: 열 이름입니다.
ASC/DESC: 인덱스가 오름차순으로 생성되는지 내림차순으로 생성되는지 여부를 나타냅니다.
TABLESPACE: 인덱스를 생성할 테이블스페이스를 식별합니다.
PCTFREE: 새로운 인덱스 항목을 수용하기 위해 생성 시 각 블록에 예약되는 공간의 양(전체 공간에서 블록 헤더를 뺀 백분율)입니다.
INITRANS: 각 블록에서 미리 할당하는 트랜잭션 항목의 수를 나타냅니다. (기본값과 최소값은 2입니다.)
MAXTRANS: 각 블록에 할당될 수 있는 트랜잭션 항목의 수를 제한합니다. (기본값은 255입니다.)
STORAGE 절: 인덱스에 확장 영역 할당하는 방법을 결정하는 저장 영역 절을 식별합니다.
LOGGING: 인덱스의 생성 및 인덱스에 대한 이후 작업을 리두 로그 파일에 기록함을 나타냅니다. (기본값입니다.)
NOLOGGING: 생성 및 특정 유형의 데이터 로드를 리두 로그 파일에 기록하지 않음을 나타냅니다.
NOSORT: 데이터베이스에 행이 오름차순으로 저장되므로 인덱스 생성 시 Oracle 서버가 행을 정렬하지 않아도 됨을 나타냅니다.


■ Creating Bitmap Indexes (비트맵 인덱스 생성)
구문
CREATE BITMAP INDEX [schema.]index
ON [schema.]table (column [ ASC | DESC ])
[ TABLESPACE tablespace ]
[ PCTFREE integer ]
[ INITRANS integer ]
[ MAXTRANS integer ]
[ storage-clause ]
[ LOGGING| NOLOGGING ]
[ NOSORT ]

예제)
CREATE BITMAP INDEX orders_region_id_idx
ON orders(region_id)
PCTFREE 30
STORAGE(INITIAL 200K NEXT 200K
PCTINCREASE 0 MAXEXTENTS 50)
TABLESPACE indx;

CREATE_BITMAP_AREA_SIZE매개변수
초기화 매개변수인 CREATE_BITMAP_AREA_SIZE는 비트맵 세그먼트를 메모리에 저장하
는 데 사용하는 공간의 양을 결정하며 기본값은 8MB입니다. 값이 클수록 인덱스를 빨리 생
성할 수 있고 기수가 아주 작은 경우에는 이 값을 작은 값으로 설정할 수 있습니다. 예를 들
어, 기수가 겨우 2이면 값을 MB가 아닌 KB 순서로 나열하며 일반적으로 기수가 높은 경우
에는 메모리가 충분해야 최적의 성능을 낼 수 있습니다.


■ Changing Storage Parameters for Indexes (인덱스 저장 영역 매개변수 변경)
구문
ALTER INDEX [schema.]index
[ storage-clause ]
[ INITRANS integer ]
[ MAXTRANS integer ]

예제)
ALTER INDEX employees_last_name_idx
STORAGE(NEXT 400K
MAXEXTENTS 100);


■ Allocating and Deallocating Index Space (인덱스 공간 할당 및 할당 해제)
구문
ALTER INDEX [schema.]index
ALLOCATE EXTENT ([SIZE integer [K|M]]
[ DATAFILE 'filename' ])

ALTER INDEX [schema.]index
DEALLOCATE UNUSED [KEEP integer [ K|M ]]

예제)
ALTER INDEX orders_region_id_idx
ALLOCATE EXTENT (SIZE 200K
DATAFILE ‘/DISK6/indx01.dbf’);

ALTER INDEX orders_id_idx
DEALLOCATE UNUSED;


■ Rebuilding Indexes (인덱스 재구축)
구문
ALTER INDEX [schema.]index REBUILD
[ TABLESPACE tablespace ]
[ PCTFREE integer ]
[ INITRANS integer ]
[ MAXTRANS integer ]
[ storage-clause ]
[ LOGGING| NOLOGGING ]
[ REVERSE | NOREVERSE ]

예제)
ALTER INDEX orders_region_id_idx REBUILD
TABLESPACE indx02;

※ 인덱스 재구축 특성
• 기존 인덱스를 데이터 소스로 사용하여 새 인덱스를 구축합니다.
• 기존 인덱스를 사용하여 인덱스를 구축할 경우에는 정렬이 필요하지 않으므로 성능이 향상됩니다.
• 새 인덱스를 구축하고 나면 이전 인덱스는 삭제되며 재구축 중에는 이전 인덱스 및 새 인덱스를 각 테이블스페이스에 모두 수용할 수 있는 충분한 공간이 필요합니다.
• 결과 인덱스는 삭제한 항목을 포함하지 않으므로 이 인덱스는 공간을 더 효율적으로 사용합니다.
• 새 인덱스를 구축하는 동안에는 질의에서 기존 인덱스를 계속 사용할 수 있습니다.

※ 재구축이 필요한 상황
• 기존 인덱스를 다른 테이블스페이스로 이동해야 할 경우로 인덱스가 테이블과 동일한 테이블스페이스에 있거나 객체를 디스크에 재분배해야 할 경우에는 이 작업이 필요할 수 있습니다.
• 인덱스에 삭제한 항목이 많이 포함되어 있는 경우로 이러한 현상은 완료된 주문은 삭제하고 새로운 주문을 높은 번호로 테이블에 추가하는 주문 테이블의 주문 번호 인덱스와 같이 변하는 인덱스에서 나타나는 일반적인 문제입니다.
  오래된 소수의 주문을 아직 처리하지 않은 경우 항목 일부만 삭제한 인덱스 최하위 블록이 몇 개 있을 수도 있습니다.
• 기존의 일반 인덱스를 역방향 키 인덱스로 변환해야 할 경우로 이전 릴리스의 Oracle 서버에서 응용 프로그램을 이전할 경우 재구축할 수 있습니다.
• 인덱스의 테이블을 ALTER TABLE ... MOVE TABLESPACE 명령을 사용하여 다른 테이블스페이스로 이동한 경우


■ Rebuilding Indexes Online (온라인 인덱스 재구축)
구문
ALTER INDEX [schema.]index REBUILD ONLINE;

예제)
ALTER INDEX orders_id_idx REBUILD ONLINE;

※ 제한사항
• 임시 테이블의 인덱스는 재구축할 수 없습니다.
• 분할된 인덱스 전체는 재구축할 수 없으므로 분할 영역 또는 서브 분할 영역을 각각 재구축해야 합니다.
• 사용되지 않은 공간은 할당을 해제할 수 없습니다.
• 해당 인덱스에 대한 PCTFREE 매개변수의 값을 전체적으로 변경할 수 없습니다.


■ Coalescing Indeses (인덱스 병합)
구문
ALTER INDEX [schema.]index COALESCE;

예제)
ALTER INDEX hr.employees_idx COALESCE;


■ Checking Indexes and Their Validity
구문
ANALYZE INDEX [schema.]index VALIDATE STRUCTURE

예제)
ANALYZE INDEX orders_region_id_idx
VALIDATE STRUCTURE;

※ 인덱스 및 유효성 검사
• 모든 인덱스 블록에 대해 손상된 블록이 있는지 확인합니다.
  이 명령을 수행해도 인덱스 항목이 테이블의 데이터에 대응되는지 여부는 확인되지 않습니다.
• INDEX_STATS 뷰를 인덱스 정보로 채웁니다.


■ Dropping Indexes (인덱스 삭제)
구문
DROP INDEX [schema.]index;

예제)
DROP INDEX hr.deptartments_name_idx;

다음 시나리오에서는 인덱스를 삭제해야 할 필요가 있습니다.
• 응용 프로그램에서 더 이상 사용하지 않는 인덱스는 삭제할 수 있습니다.
• 대량 로드를 수행하기 전에 인덱스를 삭제할 수 있으며 데이터를 대량으로 로드하기 전에 인덱스를 삭제하고 로드한 다음 다시 생성하면 다음 결과를 얻을 수 있습니다.
– 로드 성능이 향상됩니다.
– 인덱스 공간을 더 효율적으로 사용할 수 있습니다.
• 주기적으로만 사용하는 인덱스가 특히 휘발성 테이블에 기반을 두고 있을 경우에는 불필요하게 유지 관리하지 않아도 되며 대개 연말 또는 분기 말의 검토 회의에 사용할 정보를 모으기 위해 임시 질의를 생성하는 OLTP 시스템의 경우에는 불필요하게 유지 관리하지 않아도 됩니다.
• 로드 작업 같은 특정 유형의 작업 중에 인스턴스 실패가 발생하는 경우에는 인덱스를 INVALID로 표시하는데 이러한 경우에는 인덱스를 삭제하고 다시 생성해야 합니다.
• 인덱스가 훼손된 경우


■ Identifying Unused Indexes (사용되지 않은 인덱스 식별)
예제)
- 인덱스 사용에 대한 모니터링 시작
ALTER INDEX hr.dept_id_idx
MONITORING USAGE

- 인덱스 사용에 대한 모니터링 중지
ALTER INDEX hr.dept_id_idx
NOMONITORING USAGE

※ V$OBJECT_USAGE 열
INDEX_NAME: 인덱스 이름입니다.
TABLE_NAME: 해당 테이블입니다.
MONITORING: 모니터를 ON으로 설정할지 OFF로 설정할지 여부를 나타냅니다.
USED: 모니터하는 동안 인덱스가 사용되었는지 여부를 YES 또는 NO로 나타냅니다.
START_MONITORING: 인덱스에 대한 모니터의 시작 시간을 나타냅니다.
END_MONITORING: 인덱스에 대한 모니터의 중지 시간을 나타냅니다.

'Oracle 10g > 10g - Admin I' 카테고리의 다른 글

프로파일 & 유저 관리 & 권한 관리  (0) 2010.03.05
Constraints (제약 조건)  (0) 2010.03.05
Table (테이블)  (0) 2010.03.03
Tablespace 관련 명령어  (0) 2010.02.27
Redo log group & member 관련 명령어  (0) 2010.02.24
posted by I유령I 2010. 3. 4. 12:10
■ 리스트 분할 : 학과별 정보를 각각의 분할 세그먼트에 저장하는 예

SQL> select username, default_tablespace from dba_users 
  2  where username = 'HR';

USERNAME                       DEFAULT_TABLESPACE
------------------------------ ------------------------------
HR                             USERS

SQL> alter user hr          
  2  identified by hr
  3  account unlock;

User altered.

SQL> grant unlimited tablespace to hr;

Grant succeeded.

SQL> col tablespace_name format a20
SQL> col file_name format a45
SQL> create tablespace ts1
  2  datafile '/home/oracle/oradata/testdb/ts01.dbf' size 2m
  3  segment space management auto;

Tablespace created.

SQL> create tablespace ts2
  2  datafile '/home/oracle/oradata/testdb/ts02.dbf' size 2m
  3  segment space management auto;

Tablespace created.

SQL> create tablespace ts3
  2  datafile '/home/oracle/oradata/testdb/ts03.dbf' size 2m
  3  segment space management auto;

Tablespace created.

SQL> select tablespace_name, file_name
  2  from dba_data_files
  3  where tablespace_name like 'TS%';

TABLESPACE_NAME      FILE_NAME
-------------------- ---------------------------------------------
TS1                  /home/oracle/oradata/testdb/ts01.dbf
TS2                  /home/oracle/oradata/testdb/ts02.dbf
TS3                  /home/oracle/oradata/testdb/ts03.dbf

SQL> conn hr/hr
Connected.
SQL> @student <--- 없으므로 진행 불가 상태...
SQL> create table st (
  2     sno     varchar2(6)     primary key,
  3     sname   varchar2(20),
  4     sex     varchar2(2),
  5     syear   number(1),
  6     major   varchar2(20),
  7     avr     number(4,2)
  8  )
  9  partition by list (major)
 10  (  partition ma_ch values ('화학') tablespace ts1,
 11     partition ma_ph values ('물리') tablespace ts2,
 12     partition ma_all values ('생물', '식영', '유공') tablespace ts3);

Table created.

SQL> insert into st
  2  select * from student;
select * from student
              *
ERROR at line 2:
ORA-00942: table or view does not exist


SQL> 


SQL> conn / as sysdba
Connected.
SQL> col owner format a10
SQL> col segment_name format a30
SQL> col tablespace_name format a20
SQL> col table_owner format a10
SQL> col table_name format a20
SQL> col partition_name format a20
SQL> select table_owner, table_name, partition_name, tablespace_name
  2  from dba_tab_partitions
  3  where table_owner = 'HR';

TABLE_OWNER                    TABLE_NAME                     PARTITION_NAME                 TABLESPACE_NAME
------------------------------ ------------------------------ ------------------------------ --------------------
HR                             ST                             MA_CH                          TS1
HR                             ST                             MA_PH                          TS2
HR                             ST                             MA_ALL                         TS3

SQL> select table_owner, table_name, partition_name, tablespace_name
  2  from dba_tab_partitions
  3  where table_owner = 'HR';

TABLE_OWNE TABLE_NAME           PARTITION_NAME       TABLESPACE_NAME
---------- -------------------- -------------------- --------------------
HR         ST                   MA_CH                TS1
HR         ST                   MA_PH                TS2
HR         ST                   MA_ALL               TS3

SQL> select owner, table_name, partitioned
  2  from dba_tables
  3  where owner = 'HR';

OWNER      TABLE_NAME           PAR
---------- -------------------- ---
HR         REGIONS              NO
HR         LOCATIONS            NO
HR         DEPARTMENTS          NO
HR         JOBS                 NO
HR         JOB_HISTORY          NO
HR         EMPLOYEES            NO
HR         STUDENT              NO
HR         COUNTRIES            NO
HR         ST                   YES

9 rows selected.

SQL> 

주의사항
- Multicolumn Partition은 지원되지 않는다.
- NULL 값은 지정 가능하지만 MAXVAUES는 지정 불가능하다.
- 파티션 값의 리스트를 구성하는 문자열은 4K를 초과할 수 없다.


SQL> conn hr/hr 
Connected.
SQL> alter table st
  2  add partition ma_so values ('사회') tablespace ts1;

Table altered.

SQL> conn / as sysdba
Connected.
SQL> select table_owner, table_name, partition_name, tablespace_name
  2  from dba_tab_partitions
  3  where table_owner = 'HR';

TABLE_OWNE TABLE_NAME           PARTITION_NAME       TABLESPACE_NAME
---------- -------------------- -------------------- --------------------
HR         ST                   MA_CH                TS1
HR         ST                   MA_SO                TS1
HR         ST                   MA_PH                TS2
HR         ST                   MA_ALL               TS3

SQL> select owner, table_name, partitioned
  2  from dba_tables
  3  where owner = 'HR';

OWNER      TABLE_NAME           PAR
---------- -------------------- ---
HR         REGIONS              NO
HR         LOCATIONS            NO
HR         DEPARTMENTS          NO
HR         JOBS                 NO
HR         JOB_HISTORY          NO
HR         EMPLOYEES            NO
HR         STUDENT              NO
HR         COUNTRIES            NO
HR         ST                   YES

9 rows selected.

SQL> 



■ 범위 분할

범위분할의 예제
create table sale (
no      number  primary key,
goods   varchar2(20),
price   number,
s_date  date
)
partition by range (s_date)
( partition s1999 values less than (TO_DATE('01-01-2000', 'DD-MM-YYYY')) tablespace ts1,
partition s2000_01_03 values less than (TO_DATE('01-04-2000', 'DD-MM-YYYY')) tablespace ts2,
partition s2000_04_06 values less than (TO_DATE('01-07-2000', 'DD-MM-YYYY')) tablespace ts2,
partition s2000_07_09 values less than (TO_DATE('01-10-2000', 'DD-MM-YYYY')) tablespace ts3,
partition s2000_10 values less than (MAXVALUE) tablespace ts3);


SQL> conn hr/hr
Connected.
SQL> create table sale (
  2     no      number  primary key,
  3     goods   varchar2(20),
  4     price   number,
  5     s_date  date
  6  )
  7  partition by range (price)
  8  (  partition p100 values less than (100),
  9     partition p200 values less than (200),
 10     partition p300 values less than (300),
 11     partition pr_max values less than (MAXVALUE));

Table created.

SQL> alter table sale
  2  drop partition pr_max;

Table altered.

SQL> alter table sale
  2  add partition p400 values less than (400);

Table altered.

SQL> alter table sale
  2  add partition pr_max values less than (MAXVALUE)

Table altered.

SQL> conn / as sysdba
Connected.
SQL> select table_owner, table_name, partition_name, tablespace_name
  2  from dba_tab_partitions
  3  where table_owner = 'HR';

TABLE_OWNE TABLE_NAME           PARTITION_NAME       TABLESPACE_NAME
---------- -------------------- -------------------- --------------------
HR         SALE                 PR_MAX               USERS
HR         SALE                 P100                 USERS
HR         SALE                 P200                 USERS
HR         SALE                 P300                 USERS
HR         SALE                 P400                 USERS
HR         ST                   MA_CH                TS1
HR         ST                   MA_SO                TS1
HR         ST                   MA_PH                TS2
HR         ST                   MA_ALL               TS3

9 rows selected.

SQL> select owner, table_name, partitioned
  2  from dba_tables
  3  where owner = 'HR';

OWNER      TABLE_NAME           PAR
---------- -------------------- ---
HR         REGIONS              NO
HR         LOCATIONS            NO
HR         DEPARTMENTS          NO
HR         JOBS                 NO
HR         JOB_HISTORY          NO
HR         EMPLOYEES            NO
HR         STUDENT              NO
HR         COUNTRIES            NO
HR         ST                   YES
HR         SALE                 YES

10 rows selected.

SQL> 



■ 해시 분할

범위분할의 예제
create table st1 (
sno varchar2(6) primary key,
sname varchar2(20),
sex varchar2(2),
syear number(1),
major varchar2(20),
avr number(4,2)
)
partition by hash (sno)
partitions 8 store in (ts1, ts2, ts3);


SQL> conn / as sysdba
Connected.
SQL> create tablespace insa
  2  datafile '/home/oracle/oradata/testdb/insa01.dbf' size 5m;

Tablespace created.

SQL> create user insa
  2  identified by insa
  3  default tablespace insa
  4  quota unlimited on insa;

User created.

SQL> grant create session, create table to insa;

Grant succeeded.

SQL> conn insa/insa
Connected.
SQL> create table jikwon
  2  (  sabun   number(8),
  3     name    varchar2(10),
  4     address varchar2(50),
  5     salary  number(8));

Table created.

#현재 로그인중인 계정이 사용 가능한 테이블 확인
SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
JIKWON                         TABLE

#jikwon 테이블의 구조 확인
SQL> desc jikwon 
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 SABUN                                                                                                 NUMBER(8)
 NAME                                                                                                  VARCHAR2(10)
 ADDRESS                                                                                               VARCHAR2(50)
 SALARY                                                                                                NUMBER(8)

SQL> insert into jikwon
  2  values (20071114, '천만득', '서울동작구', 200);

1 row created.

SQL> select * from jikwon;

     SABUN NAME       ADDRESS                                                SALARY
---------- ---------- -------------------------------------------------- ----------
  20071114 천만득     서울동작구                                                200

#서브쿼리절을 이용한 테이블 생성
SQL> create table jikwon2
  2  as select * from jikwon;

Table created.

#서브쿼리절 이용시 특정 컬럼만으로 테이블 생성
SQL> create table jikwon3
  2  as select sabun, name from jikwon;

Table created.

SQL> desc jikwon3;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 SABUN                                                                                                 NUMBER(8)
 NAME                                                                                                  VARCHAR2(10)

#서브쿼리절을 이용해 테이블 구조만 복사 (데이터는 복사하지 않음)
SQL> create table jikwon4
  2  as select * from jikwon
  3  where 1 = 2;

Table created.

#테이블 구조 변경
#컬럼 추가
SQL> alter table jikwon
  2  add (phone number(10));

Table altered.

SQL> desc jikwon;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 SABUN                                                                                                 NUMBER(8)
 NAME                                                                                                  VARCHAR2(10)
 ADDRESS                                                                                               VARCHAR2(50)
 SALARY                                                                                                NUMBER(8)
 PHONE                                                                                                 NUMBER(10)

SQL> alter table jikwon
  2  drop column phone;

Table altered.

SQL> desc jikwon;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 SABUN                                                                                                 NUMBER(8)
 NAME                                                                                                  VARCHAR2(10)
 ADDRESS                                                                                               VARCHAR2(50)
 SALARY                                                                                                NUMBER(8)

#컬럼 삭제
#컬럼 변경으로 데이터 타입, 크기, 기본값을 변경할 수있다.
#변경 대상 컬럼에 데이터가 없을 경우에는 자유롭지만
#데이터가 있을 경우 char, varchar2 타입만 변경이 가능하며 크기 변경 시 최소 같거나 커야만 한다.
SQL> alter table jikwon
  2  modify name varchar2(15);

Table altered.

SQL> desc jikwon;
 Name                                                                                                 Null?    Type
 ----------------------------------------------------------------------------------------------------------------- -------- ----------------------------------------------------------------------------
 SABUN                                                                                                 NUMBER(8)
 NAME                                                                                                  VARCHAR2(15)
 ADDRESS                                                                                               VARCHAR2(50)
 SALARY                                                                                                NUMBER(8)

#테이블 이름 변경
SQL> rename jikwon2 to jikwon6;

Table renamed.

SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
JIKWON                         TABLE
JIKWON3                        TABLE
JIKWON4                        TABLE
JIKWON6                        TABLE

SQL> drop table jikwon6;

Table dropped.

SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
JIKWON                         TABLE
BIN$gPGFSrk7XRTgQKjADgB4bQ==$0 TABLE
JIKWON3                        TABLE
JIKWON4                        TABLE

SQL> 

#테이블 삭제 시 다른 테이블과 제약조건이 걸려있으면 삭제가 되지 않는다.
#이럴 경우에는 cascade constraints 옵션을 사용하면 삭제가 가능하다.
SQL> drop table jikwon6 cascade constraints;
posted by I유령I 2010. 3. 4. 11:30
실습: 테이블에 대한 공간 할당과 해제


SQL> analyze table hr.employees compute statistics;
analyze table hr.employees compute statistics
*
ERROR at line 1:
ORA-01502: index 'HR.EMP_NAME_IX' or partition of such index is in unusable state


SQL> select table_name, index_name, status from dba_indexes
  2  where table_name = 'EMPLOYEES';

TABLE_NAME                     INDEX_NAME                     STATUS
------------------------------ ------------------------------ --------
EMPLOYEES                      EMP_EMAIL_UK                   UNUSABLE
EMPLOYEES                      EMP_EMP_ID_PK                  UNUSABLE
EMPLOYEES                      EMP_DEPARTMENT_IX              UNUSABLE
EMPLOYEES                      EMP_JOB_IX                     UNUSABLE
EMPLOYEES                      EMP_MANAGER_IX                 UNUSABLE
EMPLOYEES                      EMP_NAME_IX                    UNUSABLE

6 rows selected.

SQL> alter index hr.emp_email_uk rebuild;

Index altered.

SQL> alter index hr.emp_emp_id_pk rebuild;

Index altered.

SQL> alter index hr.emp_department_ix rebuild;

Index altered.

SQL> alter index hr.emp_job_ix rebuild;

Index altered.

SQL> alter index hr.emp_manager_ix rebuild;

Index altered.

SQL> alter index hr.emp_name_ix rebuild;

Index altered.

SQL> select table_name, index_name, status from dba_indexes
  2  where table_name = 'EMPLOYEES';

TABLE_NAME                     INDEX_NAME                     STATUS
------------------------------ ------------------------------ --------
EMPLOYEES                      EMP_EMAIL_UK                   VALID
EMPLOYEES                      EMP_EMP_ID_PK                  VALID
EMPLOYEES                      EMP_DEPARTMENT_IX              VALID
EMPLOYEES                      EMP_JOB_IX                     VALID
EMPLOYEES                      EMP_MANAGER_IX                 VALID
EMPLOYEES                      EMP_NAME_IX                    VALID

6 rows selected.

SQL> analyze table hr.employees compute statistics;

Table analyzed.

SQL> select num_rows, blocks,empty_blocks as empty, avg_space, avg_row_len
  2  from dba_tables
  3  where owner = 'HR' and table_name = 'EMPLOYEES';

  NUM_ROWS     BLOCKS      EMPTY  AVG_SPACE AVG_ROW_LEN
---------- ---------- ---------- ---------- -----------
       107          5          3       4129          71
#NUM_ROWS : table에 저장된 row의 수
#BLOCKS : 사용중인 block (H/W 왼쪽 block의 수)
#EMPTY : 사용한 적이 없는 block (H/W 오른쪽 block의 수)
#AVG_SPACE : 사용중인 block의 평균 빈 공간 (Byte)
#AVG_ROW_LEN : row의 평균 길이

SQL> alter table hr.employees allocate extent (size 1m);

Table altered.

SQL> analyze table hr.employees compute statistics;

Table analyzed.

SQL> select num_rows, blocks,empty_blocks as empty, avg_space, avg_row_len
  2  from dba_tables
  3  where owner = 'HR' and table_name = 'EMPLOYEES';

  NUM_ROWS     BLOCKS      EMPTY  AVG_SPACE AVG_ROW_LEN
---------- ---------- ---------- ---------- -----------
       107          5        251       4129          71

SQL> alter table hr.employees deallocate unused;

Table altered.

SQL> select num_rows, blocks,empty_blocks as empty, avg_space, avg_row_len
  2  from dba_tables
  3  where owner = 'HR' and table_name = 'EMPLOYEES';

  NUM_ROWS     BLOCKS      EMPTY  AVG_SPACE AVG_ROW_LEN
---------- ---------- ---------- ---------- -----------
       107          5        251       4129          71

SQL> analyze table hr.employees compute statistics;

Table analyzed.

SQL> select num_rows, blocks,empty_blocks as empty, avg_space, avg_row_len
  2  from dba_tables
  3  where owner = 'HR' and table_name = 'EMPLOYEES';

  NUM_ROWS     BLOCKS      EMPTY  AVG_SPACE AVG_ROW_LEN
---------- ---------- ---------- ---------- -----------
       107          5          3       4129          71

SQL> select table_name, initial_extent, min_extents          
  2  from dba_tables
  3  where owner = 'HR' and table_name = 'EMPLOYEES';

TABLE_NAME                     INITIAL_EXTENT MIN_EXTENTS
------------------------------ -------------- -----------
EMPLOYEES                               65536           1

SQL> select tablespace_name, block_size, initial_extent, min_extents
  2  from dba_tablespaces
  3  where tablespace_name = 'EXAMPLE';

TABLESPACE_NAME      BLOCK_SIZE INITIAL_EXTENT MIN_EXTENTS
-------------------- ---------- -------------- -----------
EXAMPLE                    8192          65536           1

SQL> 
posted by I유령I 2010. 3. 4. 11:19
실습: 테이블의 상태 확인과 Rebuild


[oracle@ghost sql]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.1.0 - Production on Thu Mar 4 10:52:20 2010

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

Connected to an idle instance.

SQL> startup
ORACLE instance started.

Total System Global Area  285212672 bytes
Fixed Size                  1218992 bytes
Variable Size              92276304 bytes
Database Buffers          188743680 bytes
Redo Buffers                2973696 bytes
Database mounted.
Database opened.
SQL> col tablespace_name format a20
SQL> analyze table hr.employees compute statistics;

Table analyzed.

SQL> select num_rows, chain_cnt from dba_tables where table_name = 'EMPLOYEES';

  NUM_ROWS  CHAIN_CNT
---------- ----------
       107          0

SQL> create tablespace test         
  2  datafile '/home/oracle/oradata/testdb/test01.dbf' size 10m
  3  segment space management auto;

Tablespace created.

SQL> alter user hr quota 1m on test;

User altered.

SQL> conn hr/hr
Connected.
SQL> alter table employees move tablespace test;

Table altered.

SQL> conn / as sysdba
Connected.
SQL> select owner, table_name, tablespace_name from dba_tables
  2  where owner = 'HR' and table_name = 'EMPLOYEES';

OWNER                          TABLE_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------ --------------------
HR                             EMPLOYEES                      TEST

SQL> alter table hr.employees move tablespace example;

Table altered.

SQL> select owner, table_name, tablespace_name from dba_tables
  2  where owner = 'HR' and table_name = 'EMPLOYEES';

OWNER                          TABLE_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------ --------------------
HR                             EMPLOYEES                      EXAMPLE

SQL> 
posted by I유령I 2010. 3. 3. 12:42
■ Creating a Table (테이블 생성)
예제)
CREATE TABLE he.employees (
 employee_id NUMBER(6),
 first_name VARCHAR2(20),
 last_name VARCHAR2(25),
 email  VARCHAR2(25),
 phone_number VARCHAR2(20),
 hire_date DATE DEFAULT SYSDATE,
 job_id  VARCHAR2(10),
 salary  NUMBER(8,2),
 commission_pct NUMBER(2,2),
 manager_id NUMBER(6),
 department_id NUMBER(4)
);

※ 테이블생성지침
• 테이블을 별도의 테이블스페이스에 둡니다.
• 단편화를 방지하려면 지역적으로 관리되는 테이블스페이스를 사용합니다.

■ Creating Temporary Tables (임시 테이블 생성)
예제)
CREATE GLOBAL TEMPORARY TABLE
hr.employees_temp
AS SELECT * FROM hr.employees;


■ Changing Storage and Block Utilization Parameters (저장 영역 및 블록 활용 매개변수 변경)
예제)
ALTER TABLE hr.employees
PCTFREE 30
PCTUSED 50
STORAGE (
NEXT 500K
MINEXTENTS 2
MAXEXTENTS 100
);


■ Manually Allocating Extents (확장 영역 수동 할당)
구문
ALTER TABLE [schema.]table
ALLOCATE EXTENT [ ([SIZE integer [K|M]]
[DATAFILE ‘filename’]) ]

예제)
ALTER TABLE hr.employees
ALLOCATE EXTENT (SIZE 500K
DATAFILE '/disk3/data01.dbf');

※ 수정 가능한 매개변수와 수정의 함의는 다음과 같습니다.
• NEXT: Oracle 서버에서 테이블에 대해 다른 확장 영역을 할당할 때 새 값이 사용됩니다. 이후의 확장 영역 크기는 PCTINCREASE만큼 증가합니다.
• PCTINCREASE: PCTINCREASE의 변경 사항은 데이터 딕셔너리에 등록되며 Oracle 서버에서 다음 확장 영역을 할당할 때 NEXT를 재계산하는 데 사용됩니다.
  두 개의 확장 영역을 가진 테이블에서 NEXT=10K 및 PCTINCREASE=0인 경우를 가정해 볼 때 PCTINCREASE를 100으로 변경하면 할당되는 세번째 확장 영역은 10KB이고 네번째 확장 영역은 20KB이며 다섯번째 확장 영역은 40KB입니다.
• MINEXTENTS: MINEXTENTS의 값은 테이블의 현재 확장 영역 수 이하인 값으로 바꿀 수 있으며 테이블에 즉시 영향을 주지는 않지만 테이블이 잘릴 경우 사용됩니다.
• MAXEXTENTS: MAXEXTENTS의 값은 테이블의 현재 확장 영역 수 이상인 값으로 설정할 수 있으며 UNLIMITED로도 설정할 수 있습니다.
※ 제한사항
• 테이블에 대해 INITIAL의 값은 수정될 수 없습니다.
• 지정한 NEXT의 값은 지정한 값 이상인 블록 크기의 배수 값으로 반올림됩니다.


■ Nonpartitioned Table Reorganization (분할되지 않은 테이블 재구성)
예제)
ALTER TABLE hr.employees
MOVE TABLESPACE data1;

 
■ Truncating a Table (테이블 자르기)
구문
TRUNCATE TABLE [schema.]table
[{DROP | REUSE} STORAGE]

예제)
TRUNCATE TABLE hr.employees;

※ 이 명령을 사용한 결과는 다음과 같습니다.
• 테이블의 모든 행이 삭제됩니다.
• TRUNCATE TABLE은 DDL 명령이므로 실행 취소 데이터가 생성되지 않고 명령이 암시적으로 커밋됩니다.
• 해당 인덱스도 잘립니다.
• 외래 키가 참조 중인 테이블은 자를 수 없습니다.
• 이 명령을 사용할 때는 삭제 트리거가 실행되지 않습니다.


■ Dropping a Table (테이블 삭제)
구문
DROP TABLE [schema.]table
[CASCADE CONSTRAINTS]

예제)
DROP TABLE hr.department
CASCADE CONSTRAINTS;


■ Dropping a Column (열 삭제)
예제)
Removing a column from a table:
ALTER TABLE hr.employees
DROP COLUMN comments
CASCADE CONSTRAINTS [CHECKPOINT 1000];


■ Using the UNUSED Option (UNUSED 옵션 사용)
예제)
- Mark a column as unused:
ALTER TABLE hr.employees
SET UNUSED COLUMN comments
CASCADE CONSTRAINTS;

- Drop Unused columns:
ALTER TABLE hr.employees
DROP UNUSED COLUMNS [CHECKPOINT 1000];

- Continue to drop column operation:
ALTER TABLE hr.employees
DROP COLUMNS CONTINUE [CHECKPOINT 1000];

※ 열삭제시제한사항
• 객체 유형 테이블에서 열 삭제
• 중첩 테이블에서 열 삭제
• 테이블의 모든 열 삭제
• 분할 키 열 삭제
• SYS가 소유한 테이블에서 열 삭제
• 열이 기본 키일 경우 인덱스 구성 테이블에서 열 삭제
• 사용되지는 않지만 삭제되지 않은 LONG 또는 LONG RAW 열이 있으면 테이블에 LONG 또는 LONG RAW 열을 추가할 수 없습니다. 이는 테이블 describe 명령에 LONG 또는 LONG RAW 열이 없다고 나타나는 경우에도 적용됩니다.

'Oracle 10g > 10g - Admin I' 카테고리의 다른 글

프로파일 & 유저 관리 & 권한 관리  (0) 2010.03.05
Constraints (제약 조건)  (0) 2010.03.05
Index (인덱스)  (0) 2010.03.05
Tablespace 관련 명령어  (0) 2010.02.27
Redo log group & member 관련 명령어  (0) 2010.02.24
posted by I유령I 2010. 3. 2. 12:07

새로운 파라미터설정
UNDO_MANAGEMENT = AUTO [MANUAL]
UNDO_TABLESPACE = UNDOTBS1
UNDO_SUPPRESS_ERRORS = TRUE <--- 설정되어 있지 않음 (~9i)
UNDO_RETENTION = integer (시간:초)



실습 #1 현재 Undo 관련 설정 확인
#현재 Oracle Database 10g R2 버전이기 때문에 에러가 발생한다. (~9i)
SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDOTBS1
SQL> create rollback segment rbs01 tablespace users;

Rollback segment created.

SQL> alter system set undo+suppress_errors = true;
alter system set undo+suppress_errors = true
                 *
ERROR at line 1:
ORA-02065: illegal option for ALTER SYSTEM


SQL> alter system set undo_suppress_errors = true;
alter system set undo_suppress_errors = true
*
ERROR at line 1:
ORA-25138: UNDO_SUPPRESS_ERRORS initialization parameter has been made obsolete


SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDOTBS1
SQL> select segment_name from dba_segments
  2  where lower(segment_name) like 'rbs%';

no rows selected

SQL>



실습 #2 UNDO Tablespace 생성과 Default Undo Tablespace 지정
SQL> create undo tablespace undo
  2  datafile '/home/oracle/oradata/testdb/undo01.dbf' size 10m;

Tablespace created.

SQL> select tablespace_name, bytes, file_name from dba_data_files;

TABLESPACE_NAME                     BYTES FILE_NAME
------------------------------ ---------- --------------------------------------------------
USERS                             5242880 /disk3/users01.dbf
SYSAUX                          251658240 /disk1/sysaux01.dbf
UNDOTBS1                         36700160 /disk2/undotbs01.dbf
SYSTEM                          503316480 /disk1/system01.dbf
UNDO                             10485760 /home/oracle/oradata/testdb/undo01.dbf
EXAMPLE                         104857600 /disk3/example01.dbf

6 rows selected.

SQL> alter system set undo_tablespace = undo;

System altered.

SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDO
SQL> select segment_name, owner, tablespace_name, status from dba_rollback_segs;

SEGMENT_NAME                   OWNER  TABLESPACE_NAME                STATUS
------------------------------ ------ ------------------------------ ----------------
SYSTEM                         SYS    SYSTEM                         ONLINE
_SYSSMU10$                     PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU9$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU8$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU7$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU6$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU5$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU4$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU3$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU2$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU1$                      PUBLIC UNDOTBS1                       OFFLINE
_SYSSMU20$                     PUBLIC UNDO                           ONLINE
_SYSSMU19$                     PUBLIC UNDO                           ONLINE
_SYSSMU18$                     PUBLIC UNDO                           ONLINE
_SYSSMU17$                     PUBLIC UNDO                           ONLINE
_SYSSMU16$                     PUBLIC UNDO                           ONLINE
_SYSSMU15$                     PUBLIC UNDO                           ONLINE
_SYSSMU14$                     PUBLIC UNDO                           ONLINE
_SYSSMU13$                     PUBLIC UNDO                           ONLINE
_SYSSMU12$                     PUBLIC UNDO                           ONLINE
_SYSSMU11$                     PUBLIC UNDO                           ONLINE

21 rows selected.

SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDO
SQL> drop tablespace undotbs1;

Tablespace dropped.

SQL> select tablespace_name, bytes, file_name from dba_data_files;

TABLESPACE_NAME                     BYTES FILE_NAME
------------------------------ ---------- --------------------------------------------------
USERS                             5242880 /disk3/users01.dbf
SYSAUX                          251658240 /disk1/sysaux01.dbf
SYSTEM                          503316480 /disk1/system01.dbf
UNDO                             10485760 /home/oracle/oradata/testdb/undo01.dbf
EXAMPLE                         104857600 /disk3/example01.dbf

SQL> select segment_name, owner, tablespace_name, status from dba_rollback_segs;

SEGMENT_NAME                   OWNER  TABLESPACE_NAME                STATUS
------------------------------ ------ ------------------------------ ----------------
SYSTEM                         SYS    SYSTEM                         ONLINE
_SYSSMU20$                     PUBLIC UNDO                           ONLINE
_SYSSMU19$                     PUBLIC UNDO                           ONLINE
_SYSSMU18$                     PUBLIC UNDO                           ONLINE
_SYSSMU17$                     PUBLIC UNDO                           ONLINE
_SYSSMU16$                     PUBLIC UNDO                           ONLINE
_SYSSMU15$                     PUBLIC UNDO                           ONLINE
_SYSSMU14$                     PUBLIC UNDO                           ONLINE
_SYSSMU13$                     PUBLIC UNDO                           ONLINE
_SYSSMU12$                     PUBLIC UNDO                           ONLINE
_SYSSMU11$                     PUBLIC UNDO                           ONLINE

11 rows selected.

SQL> 

#현재 상태로 shutdown 했다가 startup 을 할 경우 에러가 발생한다.
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.

Total System Global Area  285212672 bytes
Fixed Size                  1218992 bytes
Variable Size              92276304 bytes
Database Buffers          188743680 bytes
Redo Buffers                2973696 bytes
Database mounted.
ORA-01092: ORACLE instance terminated. Disconnection forced


#Parameter file의 내용을 아래와 같이 편집한다.
SQL> !vi /home/oracle/product/10g/dbs/inittestdb.ora
*.undo_tablespace='UNDO' <--- 기존 설정 내용은 *.undo_tablespace='UNDOTBS1' 이다.

SQL> startup
ORACLE instance started.

Total System Global Area  285212672 bytes
Fixed Size                  1218992 bytes
Variable Size              92276304 bytes
Database Buffers          188743680 bytes
Redo Buffers                2973696 bytes
Database mounted.
Database opened.
SQL>