pgsql创建用户

创建用户

复制代码
CREATE USER username WITH PASSWORD 'password';

删除用户

复制代码
DROP USER username;

修改密码

复制代码
ALTER USER username WITH PASSWORD 'newpass';
创建只读用户(全库权限)
  1. 创建角色

    复制代码
    CREATE ROLE 用户名 WITH LOGIN PASSWORD '密码';
  2. 逐库授权(对每个数据库执行)

    复制代码
    \c 目标数据库名
    GRANT USAGE ON SCHEMA public TO 用户名;
    GRANT SELECT ON ALL TABLES IN SCHEMA public TO 用户名;
  3. 设置未来表默认权限

    复制代码
    ALTER DEFAULT PRIVILEGES IN SCHEMA public 
    GRANT SELECT ON TABLES TO 用户名;
创建全权限用户(指定数据库)
  1. 创建角色并授权连接

    复制代码
    CREATE ROLE 用户名 WITH LOGIN PASSWORD '密码';
    GRANT CONNECT ON DATABASE 库名 TO 用户名;
  2. 切换到目标数据库授权

    复制代码
    \c 库名
    GRANT USAGE ON SCHEMA public TO 用户名;
    GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO 用户名;
  3. 设置未来表默认权限

    复制代码
    ALTER DEFAULT PRIVILEGES IN SCHEMA public 
    GRANT ALL PRIVILEGES ON TABLES TO 用户名;
权限控制进阶
  • 回收权限

    复制代码
    REVOKE INSERT ON 表名 FROM 用户名;
  • 授予超级用户权限

    复制代码
    ALTER USER username WITH SUPERUSER;
相关推荐
廿一夏5 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim7 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室7 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)7 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU8 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng9 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿10 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-10 小时前
Redis 命令
数据库·redis·缓存
小江的记录本11 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`11 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存