PostgreSql角色、用户创建

PostgreSQL数据库、角色、用户创建

1、数据库角色

数据库角色与操作系统用户的观念完全不同,其可以方便的维护数据库,但不是必须的。

  • 创建数据库角色

    CREATE ROLE name;

  • 删除存在的角色

    DROP ROLE name;

  • 创建和删除用户

    CREATE USER name;

    dropuser name;

  • 检查存在的数据库角色

    SELECT rolname FROM pg_roles;

    \du #用这个命令也可以查看

  • 数据库默认用户

    数据库在安装完成后会在操作系统以及数据库中都建立一个默认的用户postgres,这个角色是“超级用户”,想使用数据库的更多功能,必须先用这个用户连接数据库。

  • 数据库连接命令

    psql -U name;

2、数据库角色属性

数据库角色有大量的属性,这些属性定义了角色的数据库登录以及操作权限。

CREATE ROLE name [ [ WITH ] option [ ... ] ]
where option can be:
SUPERUSER | NOSUPERUSER
| CREATEDB | NOCREATEDB
| CREATEROLE | NOCREATEROLE
| CREATEUSER | NOCREATEUSER
| INHERIT | NOINHERIT
| LOGIN | NOLOGIN
| REPLICATION | NOREPLICATION
| CONNECTION LIMIT connlimit
| [ ENCRYPTED | UNENCRYPTED ] PASSWORD ’password’
| VALID UNTIL ’timestamp’
| IN ROLE role_name [, ...]
| IN GROUP role_name [, ...]
| ROLE role_name [, ...]
| ADMIN role_name [, ...]
| USER role_name [, ...]
| SYSID uid
  • 登录权限

    LOGIN属性用于赋予角色拥有连接数据库权限,命令二选一

    CREATE ROLE name LOGIN;

    CREATE USER name;

    CREATE USER 和CREATE ROLE几乎相同,除了CREATE USER默认带有登录权限,CREATE ROLE没有。

  • 超级用户

    超级用户拥有数据库的所有权限,必须小心超级用户的权限赋予,命令如下

    CREATE ROLE name SUPERUSER;

  • 创建数据库权限

    CREATE ROLE name CREATEDB;

  • 创建角色权限

    CREATE ROLE name CREATEROLE;

  • 初始化复制

    CREATE ROLE name REPLICATION LOGIN;

  • 密码

    密码是用户登录数据库的客户端认证方式。密码创建后采用md5加密算法加密。
    CREATE ROLE name PASSWORD 'string';

  • 更改权限

    ALTER ROLE name SET enable_indexscan TO off;

3、角色组

角色组类似于操作系统的组权限,可以非常方便的对组内成员的权限进行管理。

可以用过GRANT和REVOKE操作进行权限的赋予和回收。

GRANT group_role TO role1, ... ;
REVOKE group_role FROM role1, ... ;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值