2

我为我的 Postgres 数据库创建了一个用户,但我无法使用我设置的用户访问数据。

在 python shell 中,我运行了以下代码:

>>> import psycopg2

>>> conn=psycopg2.connect(
database="db",
user="postgres",
host="/tmp/",
password="opensesame"
)

>>> cur = conn.cursor()

>>> state = 'Arkansas'

>>> cur.execute("SELECT city FROM table WHERE state = %s", (state,))

Traceback (most recent call last):
  File "<pyshell#8>", line 1, in <module>
    cur.execute("SELECT city FROM table WHERE state = %s", (state,))
ProgrammingError: permission denied for relation table

作为超级用户,我尝试过:

db=# ALTER USER postgres SET TO default

但这没有帮助

我需要让这个用户访问这个表,任何帮助将不胜感激。感谢您的观看。

4

2 回答 2

1

试试这个,登录 postgres

sudo -u postgres psql

然后输入\l它将列出所有表,您将看到您创建的数据库的列表,

然后

GRANT ALL ON db TO postgres;

如果一切顺利,你现在应该再做\l一次,看看你现在有特权。

于 2013-03-02T00:27:05.473 回答
0

在我的代码中,我收到了错误消息:

ProgrammingError: permission denied for relation author

虽然:

GRANT ALL ON db TO postgres;

可能会为某些人解决此错误,我后来发现: Permission denied for relationship

并发现您可能想要命名关系、序列或表而不是数据库。根据上面的链接,授予数据库权限可能更多地与访问连接有关,而不是递归地遍历表、关系和序列并授予所有这些权限。

至少,如果您遇到此错误,请阅读这篇文章和那篇文章,看看是否有任何一篇可以解决问题。

于 2014-10-16T03:44:06.937 回答