관리 메뉴

FU11M00N

[ Oracle DB] scott 스키마 설치하기, 제약 조건 설정하기 ,제약조건 스키마 , 제약 조건 확인하기 본문

Programming/Oracle SQL

[ Oracle DB] scott 스키마 설치하기, 제약 조건 설정하기 ,제약조건 스키마 , 제약 조건 확인하기

호IT 2021. 3. 8. 17:29

 

 


 

 

먼저 scott.sql 불러오겠습니다. 실습을 위한 파일.

아래는 scott.sql 파일의 내용입니다.

 

--
-- Copyright (c) Oracle Corporation 1999. All Rights Reserved.
--
-- NAME
-- demobld_scott.sql
--
-- DESCRIPTION
-- This script creates the SQL*Plus demonstration tables.
--
-- USAGE
-- SQL> @demobld_scott.sql
--
-- 
-- scott/tiger 계정 생성

-- system 계정으로 접속한다.
SET FEEDBACK 1
SET NUMWIDTH 10
SET LINESIZE 80
SET TRIMSPOOL ON
SET TAB OFF
SET PAGESIZE 999
SET ECHO OFF
SET CONCAT '.'
SET SHOWMODE OFF

-- PROMPT 
-- PROMPT specify password for SYSTEM as parameter 1:
-- DEFINE password_system     = &1

-- CONNECT system/&&password_system
-- 본스크립트는 system 계정에서 실행시켜야한다.

DROP USER scott CASCADE;

create user scott identified by tiger default tablespace users temporary tablespace temp profile default;
grant connect, resource to scott;
alter user scott account unlock;

-- 여기서 부터는 scott 계정으로 접속한다.
conn scott/tiger;

SET TERMOUT ON
PROMPT Building demonstration tables. Please wait.
SET TERMOUT OFF

DROP TABLE EMP;
DROP TABLE DEPT;
DROP TABLE BONUS;
DROP TABLE SALGRADE;
DROP TABLE DUMMY;

CREATE TABLE EMP (
	EMPNO 		NUMBER(4) NOT NULL,
	ENAME 		VARCHAR2(10),
	JOB 		VARCHAR2(9),
	MGR 		NUMBER(4),
	HIREDATE 	DATE,
	SAL 		NUMBER(7, 2),
	COMM 		NUMBER(7, 2),
	DEPTNO 		NUMBER(2)
	);

INSERT INTO EMP VALUES (7369, 'SMITH', 'CLERK', 7902,TO_DATE('1980-12-17', 'YYYY-MM-DD'), 800, NULL, 20);
INSERT INTO EMP VALUES (7499, 'ALLEN', 'SALESMAN', 7698,TO_DATE('1981-02-20', 'YYYY-MM-DD'), 1600, 300, 30);
INSERT INTO EMP VALUES (7521, 'WARD', 'SALESMAN', 7698,TO_DATE('1981-02-22', 'YYYY-MM-DD'), 1250, 500, 30);
INSERT INTO EMP VALUES (7566, 'JONES', 'MANAGER', 7839,TO_DATE('1981-04-02', 'YYYY-MM-DD'), 2975, NULL, 20);
INSERT INTO EMP VALUES (7654, 'MARTIN', 'SALESMAN', 7698,TO_DATE('1981-09-28', 'YYYY-MM-DD'), 1250, 1400, 30);
INSERT INTO EMP VALUES (7698, 'BLAKE', 'MANAGER', 7839,TO_DATE('1981-05-01', 'YYYY-MM-DD'), 2850, NULL, 30);
INSERT INTO EMP VALUES (7782, 'CLARK', 'MANAGER', 7839,TO_DATE('1981-06-09', 'YYYY-MM-DD'), 2450, NULL, 10);
INSERT INTO EMP VALUES (7788, 'SCOTT', 'ANALYST', 7566,TO_DATE('1982-12-09', 'YYYY-MM-DD'), 3000, NULL, 20);
INSERT INTO EMP VALUES (7839, 'KING', 'PRESIDENT', NULL,TO_DATE('1981-11-17', 'YYYY-MM-DD'), 5000, NULL, 10);
INSERT INTO EMP VALUES (7844, 'TURNER', 'SALESMAN', 7698,TO_DATE('1981-09-08', 'YYYY-MM-DD'), 1500, 0, 30);
INSERT INTO EMP VALUES (7876, 'ADAMS', 'CLERK', 7788,TO_DATE('1983-01-12', 'YYYY-MM-DD'), 1100, NULL, 20);
INSERT INTO EMP VALUES (7900, 'JAMES', 'CLERK', 7698,TO_DATE('1981-12-03', 'YYYY-MM-DD'), 950, NULL, 30);
INSERT INTO EMP VALUES (7902, 'FORD', 'ANALYST', 7566,TO_DATE('1981-12-03', 'YYYY-MM-DD'), 3000, NULL, 20);
INSERT INTO EMP VALUES (7934, 'MILLER', 'CLERK', 7782,TO_DATE('1982-01-23', 'YYYY-MM-DD'), 1300, NULL, 10);

CREATE TABLE DEPT(
	DEPTNO 		NUMBER(2),
	DNAME 		VARCHAR2(14),
	LOC 		VARCHAR2(13) 
	);

INSERT INTO DEPT VALUES (10, 'ACCOUNTING', 'NEW YORK');
INSERT INTO DEPT VALUES (20, 'RESEARCH', 'DALLAS');
INSERT INTO DEPT VALUES (30, 'SALES', 'CHICAGO');
INSERT INTO DEPT VALUES (40, 'OPERATIONS', 'BOSTON');

CREATE TABLE BONUS(
	ENAME 		VARCHAR2(10),
	JOB 		VARCHAR2(9),
	SAL 		NUMBER,
	COMM 		NUMBER
	);

CREATE TABLE SALGRADE(
	GRADE NUMBER,
	LOSAL NUMBER,
	HISAL NUMBER
	);

INSERT INTO SALGRADE VALUES (1, 700, 1200);
INSERT INTO SALGRADE VALUES (2, 1201, 1400);
INSERT INTO SALGRADE VALUES (3, 1401, 2000);
INSERT INTO SALGRADE VALUES (4, 2001, 3000);
INSERT INTO SALGRADE VALUES (5, 3001, 9999);

CREATE TABLE DUMMY (DUMMY NUMBER);

INSERT INTO DUMMY VALUES (0);

COMMIT;

SET TERMOUT ON
PROMPT Demonstration table build is complete.
EXIT

 

 

위 소스를 sql 확장자로 저장해줍니다.

 

 

 

 

oracle sql developer  에서 파일 > 열기를 이용해 sql 파일을 불러와 줍니다.

 

그리고 그 파일을 ctrl + enter 키를 이용해 실행시킵니다.

 

 

scott_user 계정을 만들어 주겠습니다.

 

 

 

- scott_user 만들기

 

좌측 초록색 + 버튼을 눌러 scott_user 를 추가합니다.

 

 

 

위 화면과 같이 설정해주고 테스트 해서 상태가 성공이면 저장합니다.

 

 

비밀번호는 tiger 입니다.

 

- 설치 확인

 

 

만들어진 scott_user를 더블 클릭해 워크시트를 열고 show user; 를 실행해보겠습니다.

 

 

 

 

scott 스키마 설치가 성공적으로 되었습니다.

 

 

SCOTT 을 활성화 시켜보겠습니다.

 

alter user scott identified by tiger account unlock;

 

 

이제 마지막 확인만 해보겠습니다.

 

 

select username, account_status from dba_users where username in ('HR','SCOTT');

 

위 select 문은 sys_user 에서 실행해야합니다. 

 

 

 

 

HR 은 다른 스키마이라서 상관 하지 말고, SCOTT 의 상태가 OPEN 이면 됩니다.

 

- SCOTT 스키마 확인하기

 

 

자주 사용하는 거니 알아두면 도움이 됩니다.

 

 

  • user_objects
  • user_tables
  • user_constraints
  • user_tab_columns
  • user_cons_columns

 

스키마 구조 확인은 desc 를 이용합니다.

 

 

 

 

 

 

 - 각각의 키들

 

 1)primary key(pk)

 2)foreign key(fk) -> 자식한테 설정해주면 됩니다.

   primary key 만 참조하는 것으로 알고 있었지만, oracle 에서는 unique 키도 외래키로 참조 가능합니다.

   유니크 인덱스도 가능합니다.

 3)unique key(uk)

   학교에서 학번을 pk로 주고, uk는 주민번호라고 생각하면 쉽다.  + pk 는 짧으면 좋기 때문에 그렇게 예시를 들었습니다.

 4)check(ck)

   제한두기 (점수는 0~100점까지), not null 도 check constraint 에 포함됩니다.

 5)default(df)

 

 

 

- 제약조건 확인하

 

우선 어떤 제약조건이 있는지 확인해보겠습니다.

 

 

desc user_constraints;

 

 

 

 

select owner, constraint_name,constraint_type, table_name, search_condition, r_constraint_name
from user_constraints
order by 4;

 

not null 이라는 제약조건이 결과로 도출 되는 것을 확인할 수 있습니다.

 

 

 

- 제약조건 만들기

 

-- dept 라는 테이블에 deptno 를 pk 로 설정하는 제약조건 생성
alter table dept
add constraint pk_dept_deptno primary key(deptno);

-- emp 라는 테이블에 empno 를 pk 로 설정하는 제약조건 생성
alter table emp
add constraint pk_emp_empno
primary key(empno);

-- deptno 를 외래키로 하는 제약조건 생성
alter table emp
add constraint fk_emp_deptno foreign key(deptno) references dept(deptno);

-- 제약조건 생성 확인
select owner, constraint_name,constraint_type, table_name, search_condition, r_constraint_name
from user_constraints
order by 4;

 

 

마지막 select 문을 실행하면 결과는 아래와 같이 나올 것입니다.

 

 

 

 

 

user_cons_columns 스키마와 user_constraints 스키마를 조인하여

제약조건이 어떤 컬럼에 걸려있는지도 확인할 수 있습니다.

 

select a.table_name, a.column_name,a.constraint_name,b.constraint_type 
from user_cons_columns a join user_constraints b 
on a.constraint_name=b.constraint_name;

 

 

Comments