PostgreSQL-테이블 생성

PostgreSQL CREATE TABLE 문은 주어진 데이터베이스에서 새 테이블을 만드는 데 사용됩니다.

통사론

CREATE TABLE 문의 기본 구문은 다음과 같습니다.

CREATE TABLE table_name(
   column1 datatype,
   column2 datatype,
   column3 datatype,
   .....
   columnN datatype,
   PRIMARY KEY( one or more columns )
);

CREATE TABLE은 데이터베이스 시스템에 새 테이블을 생성하도록 지시하는 키워드입니다. 테이블의 고유 이름 또는 식별자는 CREATE TABLE 문 뒤에옵니다. 처음에 현재 데이터베이스의 빈 테이블은 명령을 실행하는 사용자가 소유합니다.

그런 다음 괄호 안에 목록이 표시되어 테이블의 각 열과 데이터 유형이 무엇인지 정의합니다. 구문은 아래에 주어진 예를 통해 명확 해집니다.

다음은 ID를 기본 키로 사용하여 COMPANY 테이블을 생성하는 예이며 NOT NULL은이 테이블에 레코드를 생성하는 동안 이러한 필드가 NULL이 될 수 없음을 보여주는 제약입니다.

CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

다음 장의 연습에서 사용할 테이블을 하나 더 만듭니다.

CREATE TABLE DEPARTMENT(
   ID INT PRIMARY KEY      NOT NULL,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);

다음을 사용하여 테이블이 성공적으로 생성되었는지 확인할 수 있습니다. \d 명령은 연결된 데이터베이스의 모든 테이블을 나열하는 데 사용됩니다.

testdb-# \d

위에 주어진 PostgreSQL 문은 다음 결과를 생성합니다-

List of relations
 Schema |    Name    | Type  |  Owner
--------+------------+-------+----------
 public | company    | table | postgres
 public | department | table | postgres
(2 rows)

사용하다 \d tablename 아래에 표시된대로 각 테이블을 설명하려면-

testdb-# \d company

위에 주어진 PostgreSQL 문은 다음 결과를 생성합니다-

Table "public.company"
  Column   |     Type      | Modifiers
-----------+---------------+-----------
 id        | integer       | not null
 name      | text          | not null
 age       | integer       | not null
 address   | character(50) |
 salary    | real          |
 join_date | date          |
Indexes:
    "company_pkey" PRIMARY KEY, btree (id)