데이터베이스/SQLD
[DDL] CREATE TABLE
나는 유찌
2020. 6. 7. 11:39
SQL 전문가 가이드 책을 보며 공부하고 포스팅 하였습니다.
구문 형식
CREATE TABLE 테이블이름 (
칼럼명1 DATATYPE [DEFAULT 형식],
칼럼명2 DATATYPE [DEFAULT 형식],
칼럼명3 DATATYPE [DEFAULT 형식]
);
제약조건
제약조건 종류
구분 |
설명 |
PRIMARY KEY (기본키) |
- 행 데이터를 고유하게 식별하기 위한 기본키를 정의 - 하나의 테이블에 하나의 기본키 제약만 정의 - 기본키 제약 = 고유키 제약 & NOT NULL 제약 |
UNIQUE KEY (고유키) |
행 데이터를 고유하게 식별하기 위한 고유키를 정의 |
NOT NULL |
NULL 값의 입력을 금지 |
CHECK |
- 입력할 수 있는 값의 범위 등을 제한 - TRUE OR FALSE로 평가할 수 있는 논리식을 지정 |
FOREIGN KEY |
테이블 간의 관계를 정의하기 위해 기본키를 다른 테이블의 외래키로 복사하는 경우 외래키가 생성 |
CREATE TABLE 쿼리 예제
* oracle을 기준으로 작성하였습니다.
CREATE TABLE PLAYER (
PLAYER_ID CHAR(7) NOT NULL,
PLAYER_NAME VARCHAR(20) NOT NULL,
TEAM_ID CHAR(3) NOT NULL,
E_PLAYER_NAME VARCHAR2(40),
NICKNAME VARCHAR2(30),
JOIN_YYYY CHAR(4),
POSITION VARCHAR2(10),
BACK_NO NUMBER(2),
NATION VARCHAR2(20),
BIRTH_DATE DATE,
SOLAR CHAR(1),
HEIGHT NUMBER(3),
WEIGHT NUMBER(3),
CONSTRAINT PLAYER_PK PRIMARY KEY(PLAYER_ID),
CONSTRAINT PLAYER_FK FOREIGN KEY(TEAM_ID) REFERENCES TEAM(TEAM_ID)
);
CREATE TABLE TEAM(
TEAM_ID CHAR(3) NOT NULL,
REGION_NAME VARCHAR2(8) NOT NULL,
TEAM_NAME VARCHAR2(40) NOT NULL,
E_TEAM_NAME VARCHAR2(50),
ORIG_YYYY CHAR(4),
STADIUM_ID CHAR(3) NOT NULL,
ZIP_CODE1 CHAR(3),
ZIP_CODE2 CHAR(3),
ADDRESS VARCHAR2(80),
DDD VARCHAR2(3),
TEL VARCHAR2(10),
FAX VARCHAR2(10),
HOMEPAGE VARCHAR2(50),
OWNER VARCHAR2(10),
CONSTRAINT TEAM_PK PRIMARY KEY (TEAM_ID)
);
* 테이블 생성 시 주의 사항
- 대/소문자 구분은 하지 않는다. 하지만 기본적으로 테이블이나 칼럼명은 대문자로 만들어진다.
- 제약조건이 있으면 CONSTRANINT를 이용하여 추가합니다.
* 설명
PLAYER과 TEAM이라는 이름의 테이블을 생성하는 쿼리입니다.
PLAYER에서는 'PLAYER_ID', 'PLAYER_NAME', 'TEAM_ID'라는 칼럼에 NOT NULL 제약 조건을 통해 NULL 입력을 허용하지 않도록 합니다.
또한, 각 테이블 에 'PLAYER_ID', 'TEAM_ID' 칼럼을 기본키로 설정합니다.
PLAYER 테이블에는 TEAM 테이블의 'TEAM_ID' 칼럼을 외래키로 설정하여 두 개의 테이블의 관계를 정의합니다.