news 2026/4/16 13:03:05

6.用户及权限管理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
6.用户及权限管理

用户及权限管理

用户和角色

什么是角色?

角色是一系列相关权限的集合。为了管理方便,通常把一系列相关的数据库权限赋给一个角色,如果哪个用户需要这些权限,就把角色赋给相应的用户。

在 PostgreSQL 中,为了简化管理,角色与用户是没有区别的,一个用户也是一个角色,我们可以把一个用户的权限赋给另一个用户。

用户和角色在整个数据库实例中是全局的,在同一个实例中的不同数据库中,看到的用户都是相同的。

超级用户

  • 超级用户是初始化该数据库时与操作系统用户名相同的用户。
  • 如果数据库是建在操作系统用户postgres下的(通常我们把数据库安装在此用户下),那么这个数据库超级用户的名称也叫postgres
  • 在超级用户下可以创建更多的普通用户。

创建用户和角色

语法

CREATEROLE name[[WITH]option[...]]CREATEUSERname[[WITH]option[...]]

option 取值介绍

  • SUPERUSER|NOSUPERUSER:表示创建出来的用户是否为超级用户。
  • CREATEDB|NOCREATEDB:指定创建出来的用户是否有执行CREATE DATABASE的权限。
  • CREATEROLE|NOCREATEROLE:指定创建出来的用户是否有创建其他角色的权限。
  • CREATEUSER|NOCREATEUSER:指定创建出来的用户是否有创建其他用户的权限。
  • LOGIN|NOLOGIN:创建出来的用户是否有LOGIN权限,可以临时禁止用户的LOGIN权限,此时用户无法连接到数据库。

权限的管理

用户的权限分为两类:

第一类:创建用户时指定的权限

  1. 超级用户的权限
  2. 创建数据库的权限
  3. 是否允许LOGIN的权限

第二类:由GRANTREVOKE命令管理的权限

  1. 在数据库中创建模式(SCHEMA)的权限
  2. 允许在指定的数据库中创建临时表的权限
  3. 连接某个数据库的权限
  4. 在模式中创建数据库对象的权限,如创建表、视图、函数等
  5. 在一些表中做SELECTUPDATEINSERTDELETE等操作的权限
  6. 在一张具体的表的列上进行SELECTUPDATEINSERT操作的权限
  7. 在表上创建触发器的权限
  8. 把表、索引等建到指定表空间的权限

注意

在使用时要分清上述两类权限:

  • 如果要给用户赋予创建数据库的权限,需要使用ALTER ROLE命令。
  • 要给用户赋予创建模式的权限时,则需要使用GRANT命令。

PostgreSQL 中的 DDL 权限

PostgreSQL 没有专门的 DDL 语句权限,能否创建表取决于在模式(SCHEMA)中是否有CREATE的权限。

函数和触发器的权限

为了加强安全性,PostgreSQL 只允许超级用户使用某些 PL 语言写函数。


权限的层次总结

PostgreSQL 中的权限是按以下几个层次进行管理的:

  1. 首先管理用户特殊属性上的权限,如超级用户权限、创建数据库的权限、创建用户的权限、LOGIN权限等。
  2. 然后是在数据库中创建模式的权限。
  3. 接着是在模式中创建数据库对象的权限,如创建表、索引等。
  4. 之后是查询表、向表中插入数据、更新表、删除表中数据的权限。
  5. 最后是操作表中某些字段的权限。

如何创建一个只读用户

第一步:收回默认的创建表权限

REVOKECREATEONSCHEMApublicFROMpublic;

这是因为在 PostgreSQL 中,默认任何用户都可以在名为public的 Schema 中创建表,而只读用户是不允许创建表的,所以先要把此权限收回。

第二步:创建一个名为readonly的用户

CREATEUSERreadonlyWITHPASSWORD'query';

第三步:将现有表的 SELECT 权限赋予用户readonly

GRANTSELECTONALLTABLESINSCHEMApublicTOreadonly;

注意:上面的 SQL 命令只是把现有表的权限赋予了用户readonly,如果此时创建了新表,readonly用户仍不能读取。

第四步:设置默认权限,使新创建的表自动授权

ALTERDEFAULTPRIVILEGESINSCHEMApublicGRANTSELECTONTABLESTOreadonly;

注意:以上过程只是给名为public的 Schema 下的表赋予了只读权限,如果想让该用户访问其他 Schema 下的表,需要类似地设置相应 Schema 的权限。


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 0:21:33

FPGA实现数字噪声发生器:探索灵活的噪声生成世界

FPGA数字噪声发生器,数字噪声源,数字噪声产生,噪声源,宽带噪声源,AWGN加噪,噪声带宽可调,幅频特性可任意校正 在数字信号处理和通信等众多领域中,噪声源有着广泛的应用。今天咱们就…

作者头像 李华
网站建设 2026/4/15 22:51:17

Java程序员简历加分项:高并发经验必不可少!

如何获得高并发经验? 这是我今天系统邀请我回答的一个问题,由此也引发了我的一些思考:为什么人人都想要获得高并发经验;想拥有高并发系统设计技能? 其原因LZ认为主要有以下三点: 涨薪:有高并发…

作者头像 李华
网站建设 2026/4/16 11:14:04

2026自助洗车行业大考:美团核销接口升级背后的生存智慧

2026年伊始,遍布城市各个角落的24小时自助洗车站迎来了一场无声的“系统寒潮”。美团北极星平台的下线,让无数洗车点的核销系统突然失灵——车主无法兑换洗车券、高压水枪无法启动、会员积分系统全面停摆。杭州一位拥有12个站点的运营商王总紧急统计&…

作者头像 李华
网站建设 2026/4/11 12:12:59

2026最火副业:测试工程师的AI咨询变现路径

2026年,人工智能已彻底重塑软件测试领域,自动化工具接管了80%的重复任务,如UI验证和基础脚本生成。这看似威胁,实则开启了测试工程师的黄金副业时代——AI咨询。通过将专业经验转化为定制化解决方案,测试从业者能以顾问…

作者头像 李华