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, ... ;
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要查看PostgreSQL数据库中的用户,可以使用以下步骤: 1. 打开PostgreSQL shell或任何具有PostgreSQL访问权限的命令行工具。 2. 输入以下命令:`\du`或`SELECT * FROM pg_user;`。 第一种方法将显示所有用户及其角色和权限的列表。第二种方法将显示更详细的信息,包括用户ID、用户名、创建日期、密码哈希值等。 ### 回答2: 要查看PostgreSQL中的用户,可以使用以下两种方法: 1. 使用命令行工具psql: 首先,打开终端窗口,并输入以下命令连接到PostgreSQL数据库: ``` psql -U <用户名> -d <数据库名> ``` 其中,<用户名>是你要连接的数据库用户名,<数据库名>是你要连接的数据库名。如果你连接的是本地默认的数据库,可以省略-d参数。 然后,输入以下命令列出所有用户的信息: ``` \du ``` 这将显示所有用户的详细信息,包括用户名、角色、是否为超级用户等。 2. 使用图形化界面工具pgAdmin: 首先,打开pgAdmin并连接到你的PostgreSQL服务器。 然后,在左侧的服务器浏览器中展开服务器节点,找到你要查看的数据库。 接下来,展开该数据库节点,找到"登录/组角色"节点,右键点击并选择"属性"。 在弹出的属性窗口中,你可以查看并编辑所有用户的信息,包括用户名、角色、密码、是否为超级用户等。 无论使用哪种方法,都可以方便地查看PostgreSQL中的用户信息。 ### 回答3: 要查看 PostgreSQL 数据库中的用户,可以使用以下 SQL 命令: ``` SELECT * FROM pg_user; ``` 上述命令将返回一个包含所有数据库用户信息的结果集。查询结果将包括用户名、密码加密方式、过期日期、是否是超级用户、是否具有创建数据库权限等信息。 如果想查看特定用户的详细信息,可以使用以下 SQL 命令,将 `<username>` 替换为要查看的用户名称: ``` SELECT * FROM pg_user WHERE usename = '<username>'; ``` 上述命令将只返回特定用户的信息。 另外,还可以通过查询 `pg_roles` 系统表来查看用户角色的信息,该表包含了更详细的用户角色属性。以下是查看所有用户以及对应角色的 SQL 命令: ``` SELECT rolname, rolsuper, rolcreatedb FROM pg_roles; ``` 上述命令将返回所有用户角色的名称,以及他们是否是超级用户和是否具有创建数据库的权限。 总而言之,通过使用上述的 SQL 命令,就可以方便地查看 PostgreSQL 数据库中的用户信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值