Gino引擎未初始化

时间:2019-06-18 21:46:52

标签: sqlalchemy python-asyncio aiohttp

我正在尝试使用aiohttp和Gino创建一个简单的Restful API。

在我的终结点类中,我得到了以下内容:

class ListEndpoint(Endpoint):
def __init__(self, model):
    super().__init__()
    self.model = model

async def get(self) -> Response:
    async with db.with_bind(DB_ADDRESS):
        obj_list = await self.model.query.gino.all()

    if not obj_list:
        return Response(
            status=404,
            body=json.dumps({'Not found': 404}),
            content_type='application/json'
        )

    data = await ModelSerializer(obj_list).to_json()

    return Response(
        status=200, body=data, content_type='application/json'
    )

这是我唯一称呼吉诺的地方。这是我的main.py:

from aiohttp.web import Application, run_app

from models import Country
from resource import GenericResource


app = Application()
countries = GenericResource('countries', Country)
countries.register(app.router)


if __name__ == '__main__':
    run_app(app)

当我使用GET请求调用路由时,出现以下错误:

  

Gino引擎未初始化。

在此失败:

async with db.with_bind(DB_ADDRESS):
    obj_list = await self.model.query.gino.all()

绑定的位置不好吗?或者,据我所认为的原因,原因是该代码进入了事件循环,并且在设置obj_list时没有时间绑定。

1 个答案:

答案 0 :(得分:2)

问题是我在不同的文件中创建了Gino类的不同实例。错了作为解决方案,您应该仅创建1个Gino实例,并在不同文件之间共享。