当前位置:Gxlcms > 数据库问题 > PostgreSQL权限管理之创建可更新表的普通用户

PostgreSQL权限管理之创建可更新表的普通用户

时间:2021-07-01 10:21:17 帮助过:4人阅读

一、环境

  1. $ psql --version
  2. psql (PostgreSQL) 9.4.4

我们都知道,超级用户的权限太大了,为了数据库的安全,对于非管理员账号,需要创建普通用户。


二、语法

  1. $ psql 
  2. psql (9.4.4)
  3. Type "help" for help.
  4. postgres=# \h create role 
  5. Command:     CREATE ROLE
  6. Description: define a new database role
  7. Syntax:
  8. CREATE ROLE name [ [ WITH ] option [ ... ] ]
  9. where option can be:
  10.       SUPERUSER | NOSUPERUSER
  11.     | CREATEDB | NOCREATEDB
  12.     | CREATEROLE | NOCREATEROLE
  13.     | CREATEUSER | NOCREATEUSER
  14.     | INHERIT | NOINHERIT
  15.     | LOGIN | NOLOGIN
  16.     | REPLICATION | NOREPLICATION
  17.     | CONNECTION LIMIT connlimit
  18.     | [ ENCRYPTED | UNENCRYPTED ] PASSWORD ‘password‘
  19.     | VALID UNTIL ‘timestamp‘
  20.     | IN ROLE role_name [, ...]
  21.     | IN GROUP role_name [, ...]
  22.     | ROLE role_name [, ...]
  23.     | ADMIN role_name [, ...]
  24.     | USER role_name [, ...]
  25.     | SYSID uid


三、创建只读用户

1. 先创建表t1
  1. postgres=# create table t1 ( id serial, name varchar(64) );
  2. CREATE TABLE
  3. postgres=# \dt
  4.         List of relations
  5.  Schema | Name | Type  |  Owner   
  6. --------+------+-------+----------
  7.  public | t1   | table | postgres
  8. (1 row)
2. 创建用户u1
  1. postgres=# create role u1 with login password ‘123456‘;
  2. CREATE ROLE

login是赋予登录权限,否则是不能登录的

3. 赋予u1对表的只读权限

因为创建的普通用户默认是没有任何权限的

  1. postgres=# grant select on all tables in schema public to u1;
  2. GRANT
  3. postgres=# \c - u1
  4. You are now connected to database "postgres" as user "u1".
  5. postgres=> select * from t1;
  6.  id | name 
  7. ----+------
  8. (0 rows)
4. 创建表t2
  1. postgres=> \c - postgres
  2. You are now connected to database "postgres" as user "postgres".
  3. postgres=# create table t2 ( id serial, name varchar(64) );
  4. CREATE TABLE
  5. postgres=# \dt
  6.         List of relations
  7.  Schema | Name | Type  |  Owner   
  8. --------+------+-------+----------
  9.  public | t1   | table | postgres
  10.  public | t2   | table | postgres
  11. (2 rows)
5. 验证u1的权限
  1. postgres=# \c - u1
  2. You are now connected to database "postgres" as user "u1".
  3. postgres=> select * from t1;
  4.  id | name 
  5. ----+------
  6. (0 rows)
  7. postgres=> select * from t2;
  8. ERROR:  permission denied for relation t2

可见u1是有t1表的读权限,但没有t2表的读权限,这样是不是意味着每次新建表就要赋一次权限?

6. 解决办法
  1. postgres=> \c - postgres
  2. You are now connected to database "postgres" as user "postgres".
  3. postgres=# alter default privileges in schema public grant select on tables to u1;
  4. ALTER DEFAULT PRIVILEGES
  5. postgres=# create table t3 ( id serial, name varchar(64) );
  6. CREATE TABLE
  7. postgres=# \dt
  8.         List of relations
  9.  Schema | Name | Type  |  Owner   
  10. --------+------+-------+----------
  11.  public | t1   | table | postgres
  12.  public | t2   | table | postgres
  13.  public | t3   | table | postgres
  14. (3 rows)
  15. postgres=# \c - u1
  16. You are now connected to database "postgres" as user "u1".
  17. postgres=> select * from t3;
  18.  id | name 
  19. ----+------
  20. (0 rows)

赋予schema中所有表的默认权限给u1,这样以后新建表就不用再赋权限了。

四、创建可更新用户

1. 创建u2用户
  1. postgres=# create role u2 with login password ‘123456‘;
  2. CREATE ROLE
2. 赋予更新权限
  1. postgres=# alter default privileges in schema public grant select,insert,update,delete on tables to u2;
  2. ALTER DEFAULT PRIVILEGES
3. 创建表t4
  1. postgres=# create table t4 ( id serial, name varchar(64) );
  2. CREATE TABLE
  3. postgres=# \dt
  4.         List of relations
  5.  Schema | Name | Type  |  Owner   
  6. --------+------+-------+----------
  7.  public | t1   | table | postgres
  8.  public | t2   | table | postgres
  9.  public | t3   | table | postgres
  10.  public | t4   | table | postgres
  11. (4 rows)
4. 查看权限
  1. postgres=# \c - u2
  2. You are now connected to database "postgres" as user "u2".
  3. postgres=> insert into t4 values ( 1, ‘aa‘ );
  4. INSERT 0 1
  5. postgres=> select * from t4;
  6.  id | name 
  7. ----+------
  8.   1 | aa
  9. (1 row)
  10. postgres=> update t4 set name = ‘bb‘ where id = 1;
  11. UPDATE 1
  12. postgres=> select * from t4;
  13.  id | name 
  14. ----+------
  15.   1 | bb
  16. (1 row)
  17. postgres=> delete from t4 where id = 1;
  18. DELETE 1
  19. postgres=> select * from t4;
  20.  id | name 
  21. ----+------
  22. (0 rows)

可以正常增删改查

5. 序列的权限与解决办法

在insert的时候,指定列插入,主键id是serial类型会默认走sequence的下一个值,但前面只赋予了表的权限,所以会出现下面的问题:

  1. postgres=> insert into t4 ( name ) values ( ‘aa‘ );
  2. ERROR:  permission denied for sequence t4_id_seq

解决方法就是再赋一次sequence的值就行了

  1. postgres=> \c - postgres
  2. You are now connected to database "postgres" as user "postgres".
  3. postgres=# alter default privileges in schema public grant usage on sequences to u2;
  4. ALTER DEFAULT PRIVILEGES
  5. postgres=# create table t5 ( id serial, name varchar(64) );
  6. CREATE TABLE
  7. postgres=# \c - u2
  8. You are now connected to database "postgres" as user "u2".
  9. postgres=> insert into t5 ( name ) values ( ‘cc‘ );
  10. INSERT 0 1
  11. postgres=> select * from t5;
  12.  id | name 
  13. ----+------
  14.   1 | cc
  15. (1 row)

五、删除用户

  1. postgres=> \c - postgres
  2. You are now connected to database "postgres" as user "postgres".
  3. postgres=# drop role u2;
  4. ERROR:  role "u2" cannot be dropped because some objects depend on it
  5. DETAIL:  privileges for table t5
  6. privileges for sequence t5_id_seq
  7. privileges for default privileges on new sequences belonging to role postgres in schema public
  8. privileges for table t4
  9. privileges for default privileges on new relations belonging to role postgres in schema public

当我们删除用户的时候,会提示有权限依赖,所以我们要删除这些权限

  1. postgres=# alter default privileges in schema public revoke usage on sequences from u2;
  2. ALTER DEFAULT PRIVILEGES
  3. postgres=# alter default privileges in schema public revoke select,insert,delete,update on tables from u2;
  4. ALTER DEFAULT PRIVILEGES
  5. postgres=# revoke select,insert,delete,update on all tables in schema public from u2;
  6. REVOKE
  7. postgres=# revoke usage on all sequences in schema public from u2;
  8. REVOKE
  9. postgres=# drop role u2;
  10. DROP ROLE

这样太麻烦了,有没有更快的办法?

  1. postgres=# drop role u1;
  2. ERROR:  role "u1" cannot be dropped because some objects depend on it
  3. DETAIL:  privileges for table t5
  4. privileges for table t4
  5. privileges for table t3
  6. privileges for default privileges on new relations belonging to role postgres in schema public
  7. privileges for table t1
  8. postgres=# drop owned by u1;
  9. DROP OWNED
  10. postgres=# drop role u1;
  11. DROP ROLE


PostgreSQL权限管理之创建可更新表的普通用户

标签:

人气教程排行