English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

PostgreSQL TRUNCATE TABLE

PostgreSQL에서 TRUNCATE TABLE은 테이블 데이터를 지우지만 테이블 구조를 지우지 않습니다。

DROP TABLE을 사용하여 테이블을 지울 수도 있습니다. 하지만 이 명령어는 테이블 구조와 함께 지우기 때문에, 데이터를 입력하려면 테이블을 다시 만들어야 합니다。

TRUNCATE TABLE과 DELETE는 같은 효과을 가집니다. 하지만 실제로 테이블을 스캔하지 않기 때문에 더 빠르게 실행됩니다。 또한 TRUNCATE TABLE은 즉시 테이블 공간을 해제할 수 있으며, 이는 대형 테이블에서 매우 유용합니다。

PostgreSQL VACUUM 작업은 갱신된 공간을 해제하고 재사용하는 데 사용됩니다。/행이 차지하는 디스크 공간을 제거합니다。

문법

TRUNCATE TABLE 기본 문법은 다음과 같습니다:

TRUNCATE TABLE table_name;

온라인 예제

COMPANY 테이블 생성(COMPANY SQL 파일 다운로드 ),데이터 내용은 다음과 같습니다:

w3codeboxdb# select * from COMPANY;
 id | name  | age | address  | salary
----+-------+-----+-----------+--------
  1 | Paul  |  32 | California|  20000
  2 | Allen |  25 | Texas   |  15000
  3 | Teddy |  23 | Norway   |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas   |  85000
  6 | Kim  |  22 | South-Hall|  45000
  7 | James |  24 | Houston  |  10000
(7 rows)

아래 예제에서 TRUNCATE TABLE을 사용하여 COMPANY 테이블을 지우는 방법을 보여줍니다:

w3codeboxdb=# TRUNCATE TABLE COMPANY;

결과가 다음과 같습니다:

w3codeboxdb=# SELECT * FROM CUSTOMERS;
 id | name | age | address | salary
----+------+-----+---------+--------
(0 rows)