PostgreSQL-권한

데이터베이스에 개체가 생성 될 때마다 소유자가 할당됩니다. 소유자는 일반적으로 생성 문을 실행 한 사람입니다. 대부분의 객체 유형에서 초기 상태는 소유자 (또는 수퍼 유저) 만 객체를 수정하거나 삭제할 수 있습니다. 다른 역할 또는 사용자가 사용하도록 허용하려면 권한 또는 권한을 부여해야합니다.

PostgreSQL의 다양한 권한은 다음과 같습니다.

  • SELECT,
  • INSERT,
  • UPDATE,
  • DELETE,
  • TRUNCATE,
  • REFERENCES,
  • TRIGGER,
  • CREATE,
  • CONNECT,
  • TEMPORARY,
  • EXECUTE 및
  • USAGE

객체의 유형 (테이블, 함수 등)에 따라 권한이 객체에 적용됩니다. 사용자에게 권한을 할당하기 위해 GRANT 명령이 사용됩니다.

GRANT 구문

GRANT 명령의 기본 구문은 다음과 같습니다.

GRANT privilege [, ...]
ON object [, ...]
TO { PUBLIC | GROUP group | username }
  • privilege − 값은 SELECT, INSERT, UPDATE, DELETE, RULE, ALL이 될 수 있습니다.

  • object− 액세스 권한을 부여 할 개체의 이름. 가능한 개체는 테이블,보기, 시퀀스입니다.

  • PUBLIC − 모든 사용자를 나타내는 짧은 형식.

  • 그룹 group − 권한을 부여 할 그룹.

  • username− 권한을 부여 할 사용자의 이름. PUBLIC은 모든 사용자를 나타내는 짧은 형식입니다.

권한은 REVOKE 명령을 사용하여 취소 할 수 있습니다.

REVOKE 구문

REVOKE 명령의 기본 구문은 다음과 같습니다.

REVOKE privilege [, ...]
ON object [, ...]
FROM { PUBLIC | GROUP groupname | username }
  • privilege − 값은 SELECT, INSERT, UPDATE, DELETE, RULE, ALL이 될 수 있습니다.

  • object− 액세스 권한을 부여 할 개체의 이름. 가능한 개체는 테이블,보기, 시퀀스입니다.

  • PUBLIC − 모든 사용자를 나타내는 짧은 형식.

  • 그룹 group − 권한을 부여 할 그룹.

  • username− 권한을 부여 할 사용자의 이름. PUBLIC은 모든 사용자를 나타내는 짧은 형식입니다.

권한을 이해하기 위해 먼저 다음과 같이 USER를 생성 해 보겠습니다.

testdb=# CREATE USER manisha WITH PASSWORD 'password';
CREATE ROLE

CREATE ROLE 메시지는 USER "manisha"가 생성되었음을 나타냅니다.

다음과 같은 레코드가 있는 테이블 COMPANY 를 고려하십시오.

testdb# 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)

다음으로 테이블 COMPANY에 대한 모든 권한을 "manisha"사용자에게 다음과 같이 부여합니다.

testdb=# GRANT ALL ON COMPANY TO manisha;
GRANT

GRANT 메시지는 모든 권한이 USER에게 할당되었음을 나타냅니다.

다음으로 다음과 같이 USER "manisha"의 권한을 취소하겠습니다.

testdb=# REVOKE ALL ON COMPANY FROM manisha;
REVOKE

REVOKE 메시지는 모든 권한이 USER로부터 취소되었음을 나타냅니다.

다음과 같이 사용자를 삭제할 수도 있습니다.

testdb=# DROP USER manisha;
DROP ROLE

DROP ROLE 메시지는 USER 'Manisha'가 데이터베이스에서 삭제되었음을 나타냅니다.