首页数据库PostgreSQL 实现快速删除一个用户

PostgreSQL 实现快速删除一个用户

时间2024-02-29 13:45:03发布访客分类数据库浏览523
导读:收集整理的这篇文章主要介绍了PostgreSQL 实现快速删除一个用户,觉得挺不错的,现在分享给大家,也给大家做个参考。 背景在多租户场景或者其他场景下,很多时候需要主动清理一些用户,本...
收集整理的这篇文章主要介绍了PostgreSQL 实现快速删除一个用户,觉得挺不错的,现在分享给大家,也给大家做个参考。

背景

在多租户场景或者其他场景下,很多时候需要主动清理一些用户,本文将介绍PostgreSQL 下如何快速删除一个用户(role)。

具体方法

一般情况下直接执行 drop role xxx; 就可以把这个用户删除。但是很多时候会因为用户有依赖而报错。

权限依赖

postgres=# create role test wITh login;
    CREATE ROLEpostgres=# grant all on database postgres to test;
    GRANTpostgres=# drop role test;
    ERROR: role "test" cannot be dropPEd because some objects depend on itDETaiL: PRivileges for database postgres

可以看出,因为我们把数据库postgres 的权限赋予了test 用户,所以直接删除的时候会报错。面对这种情况,我们需要先将role 的权限所有的权限全部revoke 掉,如下:

postgres=# revoke all on database postgres From test;
    REVOKEpostgres=# drop role test;
    DROP ROLE

注意:需要把该用户在所有数据库具有权限的所有数据库对象的(表,视图,SEQUENCE)权限全部回收,才能删除该用户。

对象依赖

postgres=# create role test with LOGin;
    CREATE ROLEpostgres=# \c - testYou are now connected to database "postgres" as user "test".postgres=>
     create table test (id int);
    CREATE TABLEpostgres=# \c - postgresYou are now connected to database "postgres" as user "postgres".postgres=# drop role test;
    ERROR: role "test" cannot be dropped because some objects depend on itDETAIL: owner of table test

可以看出,因为test 用户是test 表的owner,所以删除的时候报错owner of table test。如果不需要保留该对象,则需要先把该依赖对象删除。如果需要保留该对象,则应该在删除之前先把owner 赋予别人,如下:

postgres=# ALTER TABLE test OWNER TO postgres;
    ALTER TABLEpostgres=# drop role test;
    DROP ROLE

注意:需要把该用户在所有数据库具有owner 权限的所有数据库对象(表,视图,SEQUENCE)删除或者执行alter xx owner to,才能删除该用户。

更牛逼的方法

如果不保留owner 的数据库对象

postgres=# REASSIGN OWNED BY test TO postgres;
    REASSIGN OWNEDpostgres=# DROP OWNED BY test;
    DROP OWNEDpostgres=# drop role test;
    DROP ROLE

如果保留owner 的数据库对象

postgres=# REASSIGN OWNED BY test TO postgres;
    REASSIGN OWNEDpostgres=# drop role test;
    DROP ROLE

注意:REASSIGN OWNED 需要执行者所属的role (或者子集)必须包含test 和postgres 或者是superuser。另外必须所有涉及到的数据库上都执行该以上语句才能删除用户。

补充:PostgreSQL数据库创建/删除

方法1 - 系统命令

sudo su - postgres #切换到postgres用户(系统用户)createdb weichen #创建数据库psql #直接访问数据库(默认进入本地postgres数据库)\l --查看数据库列表:q --退出列表页面\q --退出客户端dropdb weichen #删除数据库

方法2 - psql命令行

sudo -u postgres psql #登录客户端create database weichen;
     --创建数据库create database sz owner postgres;
     --创建数据库select oid,datname from pg_database;
     --查看数据库列表drop database weichen;
     --删除数据库drop database sz;
     --删除数据库

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:
  • postgresql 删除重复数据的几种方法小结
  • PostgreSQL 删除check约束的实现
  • postgresql删除主键的操作
  • postgresql 实现多表关联删除
  • Postgresql创建新增、删除与修改触发器的方法
  • PostgreSQL删除更新优化操作
  • mybatis postgresql 批量删除操作方法
  • postgresql 删除重复数据案例详解

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: PostgreSQL 实现快速删除一个用户
本文地址: https://pptw.com/jishu/632942.html
PostgreSQL用户、数据库及表的管理、操作与授权方式 PostgreSQL 自定义自动类型转换操作(CAST)

游客 回复需填写必要信息