我尝试运行简单的SQL命令:
select * from site_adzone;
我得到了这个错误
错误:关系site_adzone的权限被拒绝
这里有什么问题呢?
我也试着为其他表做选择,得到了同样的问题。我也试着这样做:
GRANT ALL PRIVILEGES ON DATABASE jerry to tom;
但我收到了控制台的回复
警告:没有特权授予“jerry”
有人知道是哪里出了问题吗?
我尝试运行简单的SQL命令:
select * from site_adzone;
我得到了这个错误
错误:关系site_adzone的权限被拒绝
这里有什么问题呢?
我也试着为其他表做选择,得到了同样的问题。我也试着这样做:
GRANT ALL PRIVILEGES ON DATABASE jerry to tom;
但我收到了控制台的回复
警告:没有特权授予“jerry”
有人知道是哪里出了问题吗?
当前回答
我遇到这个切换用户到另一个用户,也需要有相同的权利,我一直得到错误:“必须是关系xx的所有者”
修复是简单地把所有的权利从老用户给新用户:
将<老用户>授予<新用户>;
其他回答
首先连接到正确的数据库,然后运行:
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO jerry;
确保以表的所有者身份登录psql。 要找出谁拥有这些表,请使用\dt
psql -h CONNECTION_STRING DBNAME -U OWNER_OF_THE_TABLES
然后你就可以运行GRANTS了
由于您正在寻找选择权限,我建议您只授予选择权限,而不是所有权限。你可以这样做:
GRANT SELECT ON <table> TO <role>;
你应该:
使用postgres用户通过DBeaver连接数据库 在左侧选项卡上打开数据库 打开角色标签/下拉菜单 选择您的用户 在右边标签上按“权限”标签 按下模式标签 按表格标签/下拉 选择所有表 选择所有需要的权限复选框(或按授予全部) 按保存
当您以postgres用户创建一个表,然后试图以普通用户访问它时,这种情况经常发生。 在这种情况下,最好以postgres用户登录,并使用以下命令更改表的所有权:
alter table <TABLE> owner to <USER>;