Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Get NDB query length - using Python on Google App Engine

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.

like image 381
Chris Dutrow Avatar asked Aug 31 '12 18:08

Chris Dutrow


2 Answers

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.

like image 184
voithos Avatar answered Oct 14 '22 00:10

voithos


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]
like image 39
R2-D2 Avatar answered Oct 14 '22 00:10

R2-D2