5

我阅读了 Flask 的 Postgres 文档

他们说要运行 Postgres 你应该有以下代码

app = Flask(__name__) 
app.config['SQLALCHEMY_DATABASE_URI'] = postgresql://localhost/[YOUR_DB_NAME]' 
db = SQLAlchemy(app)

我怎么知道我的数据库名称?

我写了 db 作为名字 - 但我得到了一个错误

sqlalchemy.exc.OperationalError: (OperationalError) FATAL:  database "[db]" 
does not exist

如果有帮助的话,用 Flask 运行 Heroku

4

2 回答 2

22

第一步,是让 Flask + Postgresql 在本地运行,而第一步是在你机器上安装 postgresql。接下来,您应该为 postgresql 安装 python 驱动程序

对于 Windows,您可以为 postgresql 使用 windows 安装程序,为 python 驱动程序使用 windows 安装程序。

完成上述两个步骤后,您需要创建一个数据库

对于 Windows,您可以使用捆绑的 pgadminIII 工具。这是一个视频,展示了如何做到这一点。

例如,这里是您如何创建一个名为 的数据库the_database,并使用内置工具创建一个名为的用户databaseuser并使用密码:P@ssw0rdpsql

$ psql -d template1 -U postgres
template1=# CREATE USER databaseuser WITH PASSWORD 'P@ssw0rd';
template1=# CREATE DATABASE the_database;
template1=# GRANT ALL PRIVILEGES ON DATABASE the_database to databaseuser;
template1=# \q

以下是使用上述信息配置应用程序的方法:

db_conn = 'postgresql+psycopg2://databaseuser:P@ssw0rd@localhost/the_database' 
app = Flask(__name__) 
app.config['SQLALCHEMY_DATABASE_URI'] = db_conn
db = SQLAlchemy(app)
于 2012-12-09T11:01:05.337 回答
1

我没有使用 Heroku 的经验,但是从您的消息中我会说您没有运行 PostgreSQL,而且您根本没有数据库。看起来他们在这里有一些信息https://postgres.heroku.com/ :)

但是在您的主题中,您询问 localhost PostgreSQL ......因此,如果您想在本地运行设置,首先要检查的是您是否安装并运行了 PostgreSQL。如果这样做,请尝试使用 pgAdmin 或从控制台连接到它并创建数据库。如果您无法连接 - 检查端口的配置,PostgreSQL 正在侦听主机。

无论如何,我看到你在评论中发布的那些消息,只给我一个想法,即你没有创建甚至运行数据库(或者你有错误的配置)。

于 2012-12-09T07:17:28.640 回答