日付順のデータストアに対してクエリを実行しようとすると、次のエラーが発生します。
NeedIndexError: no matching index found.
The suggested index for this query is:
- kind: Message
properties:
- name: author
- name: ref
- name: date
日付順に並べ替えようとしないと、クエリはエラーなしで実行されます。データストア インデックスの下の appengine コンソールには次のように表示されます。
author ▲ , ref ▲ , date ▼
Serving
私は何を間違っていますか?日付順でクエリを実行するにはどうすればよいですか? ありがとう!
これが私のエンティティ定義です:
from google.appengine.ext import ndb
class Message(ndb.Model):
subject = ndb.StringProperty()
body = ndb.TextProperty()
date = ndb.DateTimeProperty(auto_now_add=True)
ref = ndb.StringProperty( required=True )
author = ndb.KeyProperty(required=True)
これは失敗するクエリです。
def readMessages( ref, user = None ):
query = Message.query()
query = query.filter(Message.ref == ref )
if user:
query = query.filter(Message.author == user.key )
query = query.order(Message.date)
# convert to a list so we can index like an array
return [ message for message in query ]
私のindex.yamlには以下が含まれています:
indexes:
- kind: Message
properties:
- name: author
- name: ref
- name: date
direction: desc