问题
Say I have 2 kind:
class Account(db.Model):
name = db.StringProperty()
create_time = db.DataTimeProperty()
last_login = db.DateTimeProperty()
last_update = db.DataTimeProperty()
class Relationship(db.Model)
owner = db.ReferenceProperty(Account)
target = db.ReferenceProperty(Account)
type = db.IntegerProperty()
I want to get the equivalence of following query:
SELECT target
FROM Relationship
WHERE owner = :key AND type = :type
ORDERBY target.last_login DESC
How to do that?
reference: http://www.mail-archive.com/google-appengine@googlegroups.com/msg15878.html
回答1:
There's no equivalent for that query in datastore. Some points:
- You can't select a single property.
SELECT
is alwaysSELECT *
(you select a whole entity). - You can't do joins. You need to denormalize your models to fit the queries you will perform, or perform multiple queries.
So to achieve your goal, you need to have last_login
stored in Relationship
, or have a 3rd model to serve as index for that specific query.
来源:https://stackoverflow.com/questions/3333002/need-to-order-by-properties-in-the-reference-property-any-good-solution