簡體   English   中英

SQLAlchemy:創建一個有意為空的查詢?

[英]SQLAlchemy: create an intentionally empty query?

在 SQLAlchemy 中創建有意為空的查詢的最佳方法是什么?

例如,我有一些構建查詢的函數(例如,添加WHERE子句),並且在某些時候我知道結果將為空。

創建不會返回任何行的查詢的最佳方法是什么? 類似於 Django 的QuerySet.none()

如果您需要正確的返回類型,只需返回session.query(MyObject).filter(sqlalchemy.sql.false())

評估時,這仍然會影響數據庫,但應該很快。

如果你沒有一個 ORM 類來“查詢”,你也可以使用false()session.query(sqlalchemy.false()).filter(sqlalchemy.false())

根據http://www.mail-archive.com/sqlalchemy@googlegroups.com/msg25783.html ,截至 2011 年 12 月 11 日,SQLAlchemy 中沒有EmptyQuery類型對象。

db_session(YourModel).query.filter(False)

使用 python 的True布爾文字:

_and(True, some_other_query, True, True)

是相同的:

some_other_query

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM