PostgreSQL-DROP 데이터베이스

이 장에서는 PostgreSQL에서 데이터베이스를 삭제하는 방법에 대해 설명합니다. 데이터베이스를 삭제하는 두 가지 옵션이 있습니다-

  • SQL 명령 인 DROP DATABASE를 사용합니다.
  • dropdb를 사용 하여 명령 줄 실행 파일을 사용합니다.
기존 데이터베이스를 삭제하면 데이터베이스에 저장된 전체 정보가 손실 될 수 있으므로이 작업을 사용하기 전에주의하십시오.

DROP DATABASE 사용

이 명령은 데이터베이스를 삭제합니다. 데이터베이스에 대한 카탈로그 항목을 제거하고 데이터가 포함 된 디렉토리를 삭제합니다. 데이터베이스 소유자 만 실행할 수 있습니다. 사용자 또는 다른 사람이 대상 데이터베이스에 연결되어있는 동안에는이 명령을 실행할 수 없습니다 (이 명령을 실행하려면 postgres 또는 다른 데이터베이스에 연결).

통사론

DROP DATABASE의 구문은 다음과 같습니다.

DROP DATABASE [ IF EXISTS ] name

매개 변수

표에는 설명과 함께 매개 변수가 나열됩니다.

S. 아니. 매개 변수 및 설명
1

IF EXISTS

데이터베이스가없는 경우 오류를 발생시키지 마십시오. 이 경우 통지가 발행됩니다.

2

name

제거 할 데이터베이스의 이름입니다.

psql 또는 pgAdmin III 의 자체 연결을 포함하여 열려있는 연결이있는 데이터베이스는 삭제할 수 없습니다 . 현재 연결되어있는 데이터베이스를 삭제하려면 다른 데이터베이스 또는 template1로 전환해야합니다 . 따라서이 명령에 대한 래퍼 인 dropdb 프로그램을 대신 사용하는 것이 더 편리 할 수 ​​있습니다 .

다음은 간단한 예입니다. testdb PostgreSQL 스키마에서-

postgres=# DROP DATABASE testdb;
postgres-#

dropdb 명령 사용

PostgresSQL 명령 줄 실행 파일 dropdbSQL 명령 DROP DATABASE에 대한 명령 줄 래퍼 입니다. 이 유틸리티를 통해 데이터베이스를 삭제하는 것과 서버에 액세스하는 다른 방법을 사용하는 것 사이에는 효과적인 차이가 없습니다. dropdb는 기존 PostgreSQL 데이터베이스를 파괴합니다. 이 명령을 실행하는 사용자는 데이터베이스 수퍼 유저 또는 데이터베이스 소유자 여야합니다.

통사론

dropdb 의 구문 은 다음과 같습니다.

dropdb  [option...] dbname

매개 변수

다음 표는 설명과 함께 매개 변수를 나열합니다.

S. 아니. 매개 변수 및 설명
1

dbname

삭제할 데이터베이스의 이름입니다.

2

option

dropdb가 허용하는 명령 줄 인수.

옵션

다음 표에는 dropdb가 허용하는 명령 줄 인수가 나열되어 있습니다.

S. 아니. 옵션 및 설명
1

-e

서버로 전송되는 명령을 표시합니다.

2

-i

파괴적인 작업을 수행하기 전에 확인 프롬프트를 발행합니다.

-V

dropdb 버전을 인쇄하고 종료합니다.

4

--if-exists

데이터베이스가없는 경우 오류를 발생시키지 마십시오. 이 경우 통지가 발행됩니다.

5

--help

dropdb 명령 줄 인수에 대한 도움말을 표시하고 종료합니다.

6

-h host

서버가 실행중인 시스템의 호스트 이름을 지정합니다.

7

-p port

서버가 연결을 수신하는 TCP 포트 또는 로컬 UNIX 도메인 소켓 파일 확장자를 지정합니다.

8

-U username

연결할 사용자 이름입니다.

9

-w

암호 프롬프트를 발행하지 마십시오.

10

-W

dropdb가 데이터베이스에 연결하기 전에 암호를 입력하도록 강제합니다.

11

--maintenance-db=dbname

대상 데이터베이스를 삭제하기 위해 연결할 데이터베이스의 이름을 지정합니다.

다음 예제는 OS 명령 프롬프트에서 데이터베이스를 삭제하는 방법을 보여줍니다-

dropdb -h localhost -p 5432 -U postgress testdb
Password for user postgress: ****

위의 명령은 데이터베이스를 삭제합니다. testdb. 여기, 나는postgres (template1의 pg_roles 아래에 있음) 데이터베이스를 삭제할 사용자 이름.