news 2026/6/10 13:05:45

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/6/10 10:59:08

传统行业Java程序员未来何去何从?

近两年,“大厂裁员”总是凭实力冲上各大媒体头条,身在局中的我们早已习以为常。国内的京东,阿里,腾讯,字节,快手,小米等互联网公司都以不同程度的裁员比例向社会输送人才。大量有大厂经验的卷王…

作者头像 李华
网站建设 2026/6/9 23:23:18

2026 运维转网安指南:中年技术人的转型经验与避坑要点

2023年春节后的第一个工作日,我攥着9K的薪资条站在茶水间,看着新来的95后运维同事,他本科毕业两年,薪资却比我高3K。领导找我谈话时那句"基础运维岗位竞争太激烈",像一记闷棍敲醒了我。 我每天要重复着服务…

作者头像 李华
网站建设 2026/6/10 10:53:46

数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122)

数据库管理402期 2026-01-22数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122)1 进入Supabase2 准备环境建表3 项目实战3.1 创建Recat项目3.2 连接Supabase3.3 调整页面3.4 功能验证3.5 增加功能插曲总结数据库管理-第402期 不会代码的DB…

作者头像 李华
网站建设 2026/6/10 12:31:04

手把手教你学Simulink——电机电磁兼容与可靠性场景示例:基于Simulink的电机噪声抑制控制仿真

目录 手把手教你学Simulink 一、引言:为什么“电机像拖拉机”?——噪声是用户体验的致命伤! 二、电机噪声机理:从电流到声音的传递链 关键公式: 三、应用场景:电动汽车驱动电机的静音优化 设计挑战 四、建模与实现步骤(Simulink + Simscape Electrical) 第一步…

作者头像 李华
网站建设 2026/6/7 15:18:36

收藏!AI Agent 实战指南:从0到1搞懂大模型落地核心能力

做 AI 开发、入门大模型的程序员或小白,是不是都遇过这样的瓶颈:用大模型写接口、解算法题信手拈来,可一旦碰到“批量爬取竞品数据并生成可视化分析报告”“自动化完成接口全流程测试输出可复用测试用例”这类实战场景,就瞬间卡壳…

作者头像 李华