Get NDB query length - using Python on Google App

2019-06-22 14:13发布

What is a good way to get the number of query result when using NDB on google app engine?

Attempted this:

query = NDB_Model.query(NDB_Model.some_property == some_value)
if len(query) > 0:    # <-- this throws and exception
    entity = query[0]

I apologize that this is probably a very simple question, but it was not clear to me from the docs.

2条回答
欢心
2楼-- · 2019-06-22 15:01

It seems like you just want to get the first entity from your query. That's what query.get() is for.

query = NDB_Model.query(NDB_Model.some_property == some_value)

entity = query.get()
if entity is not None:
    # Do stuff

From the docs:

Returns the first query result, if any (otherwise None). This is similar to calling q.fetch(1) and returning the first item of the list of results.

In a more general form, there's query.fetch(n) where n is the maximum number of entities to fetch. It returns a list, so you could easily check len() on that.

查看更多
趁早两清
3楼-- · 2019-06-22 15:18

To get the result count of a ndb query you can simply use count():

query = NDB_Model.query(NDB_Model.some_property == some_value)
if query.count() > 0:
    entity = query[0]
查看更多
登录 后发表回答