繁体   English   中英

如何检查 SqlAlchemy 中的查询是否返回空结果?

[英]How to check if query in SqlAlchemy returns empty result?

我想执行这样的查询:

    query = users.select().where(users.column.id == id)
    res = await database.execute(query)

然后我想通过检查res添加一些错误处理。 if not res似乎不正确。 这样做的正确方法是什么?

您可以尝试从查询中获取第一个 object 并检查它是否像这样 Null

result = users.select().where(users.column.id == id).first()
if not result:
    print('query is empty')

编辑代码的另一种方式是

res = query.first()

然后检查是否是 Null

根据查询的复杂性,将其包装在SELECT EXISTS(...)中可能比SELECT... LIMIT 1更便宜,正如 Antonio 所描述的。 PostgreSQL 可能知道将这些查询视为相同,但根据此答案,并非所有 DBMS 都可能这样做。

这种解决方案的美妙之处在于它一旦找到任何结果就存在——它做的工作尽可能少,因此尽可能便宜。 SQLAlchemy中,这将是sa.select([sa.exists(query)])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM