【问题标题】:How To Run Postgres locally如何在本地运行 Postgres
【发布时间】:2012-11-26 21:15:42
【问题描述】:

我阅读了 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

【问题讨论】:

  • 我其实不知道自己在做什么——这是我的第一次。我尝试使用 createdb db 创建数据库,但出现以下错误 - 无法连接到数据库 postgres:无法连接到服务器:没有这样的文件或目录
  • 所以我认为我从来没有创建过一个,因为我遇到了一个错误。我应该怎么做/我应该如何创建一个 - createdb db - 对我不起作用?
  • @ErwinBrandstetter:你能帮忙吗?你知道我的问题的答案吗?
  • P.S. Postgre 是一个很酷的名字,它代表 Post Gangsta Rap Extreme

标签: python postgresql heroku flask


【解决方案1】:

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

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

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

【讨论】:

    【解决方案2】:

    第一步,是让 Flask + Postgresql 在本地运行,而这样做的第一步install postgresql on your machine。接下来,您应该安装python drivers for postgresql

    对于 Windows,您可以使用 windows installer for postgresqlwindows installer for the python drivers

    完成以上两步后,需要create a database

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

    例如,下面是如何创建一个名为the_database 的数据库,并使用内置工具psql 创建一个名为databaseuser 的用户,密码为P@ssw0rd

    $ 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)
    

    【讨论】:

    • 谢谢您,Khalid 先生 - 我在使用 Postgres 时遇到问题 - 终于让它工作了 - 第 8 次尝试安装它。
    猜你喜欢
    • 1970-01-01
    • 2013-06-28
    • 2021-06-06
    • 2021-09-25
    • 2017-08-15
    • 1970-01-01
    • 2017-08-24
    • 2018-11-16
    • 2019-08-23
    相关资源
    最近更新 更多