Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/database/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 强制编码/数据库使用asyncpg而不是psycopg2_Python_Database_Postgresql_Fastapi_Asyncpg - Fatal编程技术网

Python 强制编码/数据库使用asyncpg而不是psycopg2

Python 强制编码/数据库使用asyncpg而不是psycopg2,python,database,postgresql,fastapi,asyncpg,Python,Database,Postgresql,Fastapi,Asyncpg,最近,我尝试在我的postgres db中使用encode/databases包。我都做对了。但当我使用uvicorn运行它时,我看到它显示未安装psycopg2。我不想使用psycopg2。因此,我重述了所有数据库,并运行数据库[postgresql],而不是仅运行数据库。我还安装了asyncpg。但我仍然看到同样的错误。我也在虚拟环境中做任何事情。我的代码附在下面: import databases, sqlalchemy, asyncpg from fastapi import FastA

最近,我尝试在我的postgres db中使用encode/databases包。我都做对了。但当我使用uvicorn运行它时,我看到它显示未安装psycopg2。我不想使用psycopg2。因此,我重述了所有数据库,并运行数据库[postgresql],而不是仅运行数据库。我还安装了asyncpg。但我仍然看到同样的错误。我也在虚拟环境中做任何事情。我的代码附在下面:

import databases, sqlalchemy, asyncpg
from fastapi import FastAPI

#POSTGRES DATABASE
DATABASE_URL = "postgresql://xxxxxxxxxxx" # hidden
database = databases.Database(DATABASE_URL)
metadata = sqlalchemy.MetaData()

users = sqlalchemy.Table(
    "py_users",
    metadata,
    sqlalchemy.Column("id"        , sqlalchemy.String, primary_key=True),
    sqlalchemy.Column("username"  , sqlalchemy.String),
    sqlalchemy.Column("password"  , sqlalchemy.String),
    sqlalchemy.Column("first_name", sqlalchemy.String),
    sqlalchemy.Column("last_name" , sqlalchemy.String),
    sqlalchemy.Column("gender"    , sqlalchemy.CHAR  ),
    sqlalchemy.Column("created_at", sqlalchemy.String),
    sqlalchemy.Column("status"    , sqlalchemy.CHAR  ),
)

engine = sqlalchemy.create_engine(
    DATABASE_URL
)
metadata.create_all(engine)

app = FastAPI()

@app.get('/users')
def find_all_users():
    return "List All Users"
回溯是:

INFO:     Uvicorn running on http://0.0.0.0:8000 (Press CTRL+C to quit)
INFO:     Started reloader process [110] using statreload
Process SpawnProcess-1:
Traceback (most recent call last):
  File "/usr/lib/python3.8/multiprocessing/process.py", line 315, in _bootstrap
    self.run()
  File "/usr/lib/python3.8/multiprocessing/process.py", line 108, in run
    self._target(*self._args, **self._kwargs)
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/subprocess.py", line 61, in subprocess_started
    target(sockets=sockets)
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/_impl/asyncio.py", line 47, in run
    loop.run_until_complete(self.serve(sockets=sockets))
  File "/usr/lib/python3.8/asyncio/base_events.py", line 616, in run_until_complete
    return future.result()
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/_impl/asyncio.py", line 54, in serve
    config.load()
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/config.py", line 306, in load
    self.loaded_app = import_from_string(self.app)
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/importer.py", line 23, in import_from_string
    raise exc from None
  File "/home/runner/HelloCoderFastAPITuto/env/lib/python3.8/site-packages/uvicorn/importer.py", line 20, in import_from_string
    module = importlib.import_module(module_str)
  File "/usr/lib/python3.8/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1014, in _gcd_import
  File "<frozen importlib._bootstrap>", line 991, in _find_and_load
  File "<frozen importlib._bootstrap>", line 975, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 671, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 783, in exec_module
  File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
  File "./main.py", line 22, in <module>
    engine = sqlalchemy.create_engine(
  File "/opt/virtualenvs/python3/lib/python3.8/site-packages/sqlalchemy/engine/__init__.py", line 500, in create_engine
    return strategy.create(*args, **kwargs)
  File "/opt/virtualenvs/python3/lib/python3.8/site-packages/sqlalchemy/engine/strategies.py", line 87, in create
    dbapi = dialect_cls.dbapi(**dbapi_args)
  File "/opt/virtualenvs/python3/lib/python3.8/site-packages/sqlalchemy/dialects/postgresql/psycopg2.py", line 778, in dbapi
    import psycopg2
ModuleNotFoundError: No module named 'psycopg2'
从上面的错误中,我认为包数据库试图使用psycopg2而不是asyncpg。在这种情况下,如何强制数据库包使用asyncpg而不是psycopg2。如果不是这样,我如何使用asyncpg而不是psycopg2

提前谢谢

我的问题可能有一些错误。请忽略这些愚蠢的错误,如果你在我的问题中发现任何错误,请编辑该问题。

清楚地指出,我引用:

请注意,如果您正在使用任何同步SQLAlchemy函数,例如engine.create_all或alembic迁移,那么您仍然需要安装同步DB驱动程序:psycopg2 for PostgreSQL和pymysql for MySQL

您的程序中有一段代码:

engine=sqlalchemy.create\u引擎 数据库地址 metadata.create_allengine 条例草案清楚列明,我引述:

请注意,如果您正在使用任何同步SQLAlchemy函数,例如engine.create_all或alembic迁移,那么您仍然需要安装同步DB驱动程序:psycopg2 for PostgreSQL和pymysql for MySQL

您的程序中有一段代码:

engine=sqlalchemy.create\u引擎 数据库地址 metadata.create_allengine
不,在你的例子中,SQLAlchemy试图使用psycopg2

请参见错误:

opt/virtualenvs/python3/lib/python3.8/site-packages/sqlalchemy/dialogs/postgresql/psycopg2.py

声明表时,由SQLAlchemy完成。但这两者之间的连接是由asyncpg完成的

在文件中明确指出

使用asyncpg之一提供驱动程序支持


所以你不必为此担心。Encode将使用asyncpg。

不,在您的例子中,SQLAlchemy尝试使用psycopg2

请参见错误:

opt/virtualenvs/python3/lib/python3.8/site-packages/sqlalchemy/dialogs/postgresql/psycopg2.py

声明表时,由SQLAlchemy完成。但这两者之间的连接是由asyncpg完成的

在文件中明确指出

使用asyncpg之一提供驱动程序支持


所以你不必为此担心。Encode将使用asyncpg。

对于SQLAlchemy,您需要一个不同的连接字符串

数据库URL=postgresql://xxxxxxxxxxx 数据库库的数据库url 数据库\u URL\u SQLALCHEMY=postgresql+asyncpg://xxxxxxxxxxx SQLAlchemy的数据库url 此外,metadata.create_allengine也无法工作,因为该函数不包含可等待的挂钩


签出以获取更多信息。

SQLAlchemy需要不同的连接字符串

数据库URL=postgresql://xxxxxxxxxxx 数据库库的数据库url 数据库\u URL\u SQLALCHEMY=postgresql+asyncpg://xxxxxxxxxxx SQLAlchemy的数据库url 此外,metadata.create_allengine也无法工作,因为该函数不包含可等待的挂钩


签出以获取更多信息。

也非常感谢。也非常感谢。异步解决方案是什么?异步创建表?数据库和应用程序之间的连接应该是异步的。为什么您认为有问题。异步解决方案是什么?异步创建表?数据库和应用程序之间的连接应该是异步的。你为什么认为有什么不对劲。