を含まなければならない私は(直接データベース上でテスト)このSQL文の結果は私のviews.py
生のクエリはプライマリキー
Message.objects.raw('''
SELECT s1.ID, s1.CHARACTER_ID, MAX(s1.MESSAGE) MESSAGE, MAX(s1.c) occurrences
FROM
(SELECT ID, CHARACTER_ID, MESSAGE, COUNT(*) c
FROM tbl_message WHERE ts > DATE_SUB(NOW(), INTERVAL %s DAY) GROUP BY CHARACTER_ID,MESSAGE) s1
LEFT JOIN
(SELECT ID, CHARACTER_ID, MESSAGE, COUNT(*) c
FROM tbl_message WHERE ts > DATE_SUB(NOW(), INTERVAL %s DAY) GROUP BY CHARACTER_ID,MESSAGE) s2
ON s1.CHARACTER_ID=s2.CHARACTER_ID
AND s1.c < s2.c
WHERE s2.c IS NULL
GROUP BY CHARACTER_ID
ORDER BY occurrences DESC''', [days, days])
に生のSQL文を得た:
ID | CHARACTER_ID | MESSAGE | OCCURENCES
----+--------------+---------+--------------
148 | 10 | test | 133
しかし、すべてのI持っているInvalidQuery
情報の例外Raw query must include the primary key
私はdocsを確認し、次に読んだ:
プライマリキー フィールドを除外できないフィールドは1つだけです。プライマリキーを含めるのを忘れた場合、InvalidQuery例外が発生します。
ご覧のとおり、要求されたプライマリキーが私のステートメントに追加されています。どうしましたか?
class Message(models.Model):
character = models.ForeignKey('Character')
message = models.TextField()
location = models.ForeignKey('Location')
ts = models.DateTimeField()
class Meta:
pass
def __unicode__(self):
return u'%s: %s...' % (self.character, self.message[0:20])
この問題は解決していますか? – dusan
私はビューを使って回避策を講じましたが、解決策があれば投稿してください。 – Thomas
'Message'モデルを投稿できますか? – dusan