中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

postgresql數據庫刪除用戶的方法

發布時間:2020-07-18 11:22:43 來源:億速云 閱讀:258 作者:清晨 欄目:編程語言

這篇文章將為大家詳細講解有關postgresql數據庫刪除用戶的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

將介紹PostgreSQL下如何快速刪除一個用戶(role)。

一般情況下直接執行 drop role xxx; 就可以把這個用戶刪除。但是很多時候會因為用戶有依賴而報錯。

推薦:postgresql教程

權限依賴

postgres=# create role test with login;
CREATE ROLE
postgres=# grant all on database postgres to test;
GRANT
postgres=# drop role test;
ERROR:  role "test" cannot be dropped because some objects depend on it
DETAIL:  privileges for database postgres

可以看出,因為我們把數據庫postgres 的權限賦予了test 用戶,所以直接刪除的時候會報錯。面對這種情況,我們需要先將role 的權限

所有的權限全部revoke 掉,如下:

postgres=# revoke all on database postgres from test;
REVOKE
postgres=# drop role test;
DROP ROLE

注意:需要把該用戶在所有數據庫具有權限的所有數據庫對象的(表,視圖,SEQUENCE)權限全部回收,才能刪除該用戶。

對象依賴

postgres=# create role test with login;
CREATE ROLE
postgres=# \c - test
You are now connected to database "postgres" as user "test".
postgres=> create table test (id int);
CREATE TABLE
postgres=# \c - postgres
You are now connected to database "postgres" as user "postgres".
postgres=# drop role test;
ERROR:  role "test" cannot be dropped because some objects depend on it
DETAIL:  owner of table test

可以看出,因為test 用戶是test 表的owner,所以刪除的時候報錯owner of table test。如果不需要保留該對象,則需要先把該依賴對象

刪除。如果需要保留該對象,則應該在刪除之前先把owner 賦予別人,如下:

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

注意:需要把該用戶在所有數據庫具有owner 權限的所有數據庫對象(表,視圖,SEQUENCE)刪除或者執行alter xx owner to,才能

刪除該用戶。

關于postgresql數據庫刪除用戶的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南木林县| 建昌县| 渭南市| 天津市| 霸州市| 广宁县| 黔东| 曲靖市| 汉中市| 内乡县| 莎车县| 思南县| 西平县| 新河县| 靖江市| 赫章县| 朝阳市| 六盘水市| 济宁市| 文昌市| 祁门县| 扶沟县| 太保市| 额济纳旗| 宜宾市| 通化县| 定日县| 綦江县| 雅江县| 方城县| 潢川县| 常德市| 九寨沟县| 蒲江县| 大田县| 东宁县| 陈巴尔虎旗| 江达县| 瓦房店市| 定结县| 涟水县|