PostgreSQL 是一个强大的开源对象关系型数据库管理系统
- 用户权限: 用户权限是针对特定数据库用户的权限设置。每个用户在 PostgreSQL 中都有一个唯一的角色,具有一定的操作权限。用户可以通过 GRANT 和 REVOKE 语句来分配或撤销权限。用户权限主要包括以下几种:
- SELECT:查询数据
- INSERT:插入数据
- UPDATE:更新数据
- DELETE:删除数据
- TRUNCATE:截断表
- REFERENCES:创建外键约束
- TRIGGER:触发器执行
- USAGE:使用序列、类型等
- CREATE:创建对象(如表、索引等)
- TEMPORARY:创建临时表
- EXECUTE:执行函数或存储过程
- ALL PRIVILEGES:所有权限
- public 权限: public 是一个特殊的角色,代表所有数据库用户。当你为 public 角色分配权限时,这些权限将应用于所有现有用户以及未来创建的用户。public 权限通常用于为所有用户提供基本的访问权限,例如查询只读表。
用户权限与 public 权限的关系: 用户权限是针对特定用户的权限设置,而 public 权限是针对所有用户的权限设置。当用户具有特定权限时,该权限将覆盖 public 权限。换句话说,如果用户被授予了特定的权限,那么他们将具有该权限,无论 public 权限如何。如果用户没有被授予特定权限,那么他们将继承 public 权限。
总之,public 权限是一种默认权限设置,适用于所有用户。用户权限是针对特定用户的权限设置,它们可以覆盖 public 权限。在实际应用中,通常会先为 public 角色分配基本权限,然后根据需要为特定用户分配更高级别的权限。