0

「ObjectId」でフィールドを取得するメソッドを見つけています

しかし、私は見つかりませんでした。

Entries モデルを宣言しました

class Entries(models.Model):
    subject = models.CharField(max_length=120, null=False)
    content = models.TextField(null=False)
    created = models.DateTimeField(auto_now_add=True, auto_now=True)
    writer = models.CharField(max_length=30, null=False)


@csrf_exempt
def viewPost(request, entry_number): # ex) entry_number = '513c780210ae920f58762d3d'
    e = Entries.objects.get(id = entry_number) # error!!
    return HttpResponse('zz')

コードでエラーが発生するため、アンダーコードを試しました。

e = Entries.objects.get(_id = entry_number) # error!!
e = Entries.objects.get(pk = entry_number) # error!!
e = Entries.objects.get(id = entry_number) # error!!
e = Entries.objects.get(_id = ObjectId(entry_number)) # error!!
e = Entries.objects.get(pk = ObjectId(entry_number)) # error!!
e = Entries.objects.get(id = ObjectId(entry_number)) # error!!
e = Entries.objects(id = entry_number) # error!!

メッセージを見せて

'invalid literal for int() with base 10: '513c780210ae920f58762d3d', ...

したがって、今はpymongoを使用しています(djangoのORMなし)

d = entries_table.find_one({'_id' : ObjectId(entry_number)})
return render_to_response('view.html', {'ROOT_URL':ROOT_URL,
                                        'entry':d, 'id':d['_id']})

誰か私が使うのを手伝って

4

1 に答える 1

0

現在、Django ORM は MongoDB をサポートしていません。代わりに PyMongo を使用してください。

于 2013-03-10T13:53:40.480 に答える