SQLAlchemy,获取对象未绑定到会话

发布于 2021-01-29 19:34:38

我正在尝试从数据库中获取对象的集合,并将其传递给未连接到数据库的另一个进程。我的代码看起来像下面的代码,但我不断得到:

sqlalchemy.exc.UnboundExecutionError: Instance <MyClass at 0x8db7fec> is not bound to a Session; attribute refresh operation cannot proceed

当我尝试查看get_list()方法之外的列表元素时。

def get_list (obj):
    sesson = Session()
    lst = session.query(MyClass).all()
    session.close()
    return lst

但是,如果我使用这个:

def get_list_bis (obj)
    session = Session()
    return session.query(MyClass).all()

我能够使用这些元素,但是担心会话的状态,因为它没有关闭。

我在这里想念什么?

关注者
0
被浏览
75
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    如果希望通过查询会话产生的一堆对象在该会话范围之外可用,则需要删除它们以用于该会话。

    在第一个函数示例中,您将需要添加一行:

    session.expunge_all()
    

    之前

    session.close()
    

    更笼统地说,就像第一个示例一样,会话没有立即关闭。也许这是一个会话,在整个Web请求期间或类似期间都保持活动状态。在这种情况下,您不想这样做expunge_all。您将需要更加外科手术:

    for item in lst:
        session.expunge(item)
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看