使用 PostgreSQL 9.5 在 Django 1.9 中执行“python manage.py migrate”时出现错误“django.db.utils.OperationalError”

Posted

技术标签:

【中文标题】使用 PostgreSQL 9.5 在 Django 1.9 中执行“python manage.py migrate”时出现错误“django.db.utils.OperationalError”【英文标题】:Getting error 'django.db.utils.OperationalError' when doing 'python manage.py migrate' in Django 1.9 with PostgreSQL 9.5 【发布时间】:2016-07-07 03:08:19 【问题描述】:

我是编程和学习 Web 开发的新手。我已经安装了 -Django 1.9 -postgresql 9.5 -psycopg2(使用 whl 文件)用于 Windows 7 操作系统上的 postgresql 的 db api。

我已经在我的 settings.py 文件中为我的项目设置了数据库连接,如下所示。

 DATABASES = 
 'default': 
 'ENGINE': 'django.db.backends.postgresql', 
'NAME': 'Test', 
'User': 'postgres', 
'PASSWORD': 'admin', 
'HOST': 'localhost', 
'PORT': '5432', 
 

但是当我运行迁移时,我遇到了以下问题。我想将 postgres 连接到我的 django 请参阅下面的错误:

Traceback (most recent call last):
 File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 199, in ensure_connection
self.connect()
 File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 171, in connect
self.connection = self.get_new_connection(conn_params)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\postgresql\base.py", line 175, in get_new_connection
    connection = Database.connect(**conn_params)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\psycopg2\__init__.py", line 164, in connect
    conn = _connect(dsn, connection_factory=connection_factory, async=async)psycopg2.OperationalError
The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "manage.py", line 10, in <module>
   execute_from_command_line(sys.argv)
 File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\core\management\__init__.py", line 353, in         execute_from_command_line
    utility.execute()
   File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
 -packages\django\core\management\__init__.py", line 345, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
 -packages\django\core\management\base.py", line 348, in run_from_argv
self.execute(*args, **cmd_options)
   File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
 -packages\django\core\management\base.py", line 399, in execute
output = self.handle(*args, **options)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
 -packages\django\core\management\commands\migrate.py", line 89, in handle
executor = MigrationExecutor(connection, self.migration_progress_callback)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\migrations\executor.py", line 20, in __init__
self.loader = MigrationLoader(self.connection)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\migrations\loader.py", line 49, in __init__
self.build_graph()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\migrations\loader.py", line 176, in build_graph
self.applied_migrations = recorder.applied_migrations()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\migrations\recorder.py", line 65, in applied_migrations
self.ensure_schema()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\migrations\recorder.py", line 52, in ensure_schema
if self.Migration._meta.db_table in self.connection.introspection.table_names(self.connection.cursor()):
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 231, in cursor
cursor = self.make_debug_cursor(self._cursor())
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 204, in _cursor
self.ensure_connection()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 199, in ensure_connection
self.connect()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
  -packages\django\db\utils.py", line 95, in __exit__six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
 -packages\django\utils\six.py", line 685, in reraise
raise value.with_traceback(tb)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
  -packages\django\db\backends\base\base.py", line 199, in ensure_connection
self.connect()
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\django\db\backends\base\base.py", line 171, in connect
self.connection = self.get_new_connection(conn_params)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django\db\backends\postgresql\base.py", line 175, in get_new_connection
   connection = Database.connect(**conn_params)
  File "C:\Users\agarwal.s.13\AppData\Local\Programs\Python\Python35-32\lib\site
-packages\psycopg2\__init__.py", line 164, in connect
conn = _connect(dsn, connection_factory=connection_factory, async=async)
django.db.utils.OperationalError

我已经用 python 脚本检查了 psycopg2 能够在 postgresql 中连接数据库,但是当我从 django 项目运行迁移时,它不工作并且出现上述错误。

【问题讨论】:

您需要帮助。你需要解释问题。不描述你的设置就不仅仅是给出错误 @davka 我是编程和学习 Web 开发的新手。我已经为 postgresql 安装了 Django 1.9 和 postgresql 9.5 和 psycopg2 db api。现在我已经在我的 setting.py 文件中为我的项目设置了数据库连接,如下所示。数据库 = 'default': 'ENGINE': 'django.db.backends.postgresql', # 'NAME': 'Test', 'User': 'postgres', 'PASSWORD': 'admin', 'HOST' : '', 'PORT': '', 但是当我运行迁移时,我遇到了上述问题。我想将 postgres 连接到我的 django。 【参考方案1】:

您需要在 DATABASES 设置中将“用户”更改为“用户”。

【讨论】:

【参考方案2】:

您的 postgres 服务器未启动。您需要先启动服务器。 Django 不附带 postgres 或任何数据库服务器。它为这些数据库服务器提供连接器和 ORM。安装 postgres ,根据您在 django 中的 DATABASE 设置创建用户和数据库,错误应该会消失。 如果你不知道如何安装 postgres,然后谷歌。 希望这会有所帮助。

【讨论】:

Postgresql 9.5(带有用户和数据库)安装在机器上并且服务器正在运行。我可以通过 python 脚本连接到它(创建表或传递 sql 查询),但不能使用“迁移”从 django 迁移。遇到错误。 设置没有HOST。数据库 = 'default': 'ENGINE': 'django.db.backends.postgresql', 'NAME': 'Test', 'User': 'postgres', 'PASSWORD': 'admin', 'HOST': 'localhost', 'PORT': '5432', 它在本地服务器上运行。我已经为数据库尝试了默认端口“5432”的“localhost”或“127.0.0.1”,但没有任何工作。 :( 您的帖子显示错误的数据库设置,没有主机。所以我就问了。 它是 DATABASES = 'default': 'ENGINE': 'django.db.backends.postgresql', 'NAME': 'Test', 'User': 'postgres', 'PASSWORD ': 'admin', 'HOST': 'localhost', 'PORT': '5432', 但同样的错误

以上是关于使用 PostgreSQL 9.5 在 Django 1.9 中执行“python manage.py migrate”时出现错误“django.db.utils.OperationalError”的主要内容,如果未能解决你的问题,请参考以下文章

如何在 PostgreSQL 9.5 中为“int”数据类型设置大小限制

如何在 PostgreSQL 9.5 中为“int”数据类型设置大小限制

在 PostgreSQL 9.5+ 中追加(推送)和从 JSON 数组中删除

如何提高 PostgreSQL 9.5 中的查询性能?

是否可以使用 pg-promise 和 PostgreSQL(9.5)“创建数据库 ...”?

PostgreSQL 9.5 - 行级安全/ROLE 最佳实践