Django'da filtreli en son kaydı alın


92

En son Django model nesnesini almaya çalışıyorum ama başarılı olamıyorum.

Bunların hiçbiri çalışmıyor:

obj = Model.objects.filter(testfield=12).latest()
obj = Model.objects.latest().filter(testfield=12)

3
Denedin mi:obj= Model.objects.filter(testfield=12).order_by('-id')[:1]
catherine

@catherine, bir cazibe gibi çalışıyor! : D. Bunu cevap olarak yazmak istiyorsun, böylece kontrol edebileyim?
2013

2018 yılında NewsPostImage.objects.filter(newsPostTarget=img_id).first(). Umarım yardımcı olur.
Ngatia Frankline

Yanıtlar:


104
obj= Model.objects.filter(testfield=12).order_by('-id')[0]

10
@DaveMerwin yanlış değil; Bu sorunu çözmenin birçok yolu vardır ve hem bu cevap hem de diğeri doğrudur.
Ürdün

1
Bunun, id'nin sıralı bir birincil anahtar tamsayı olduğu varsayımını yaptığına dikkat edin. Bu normalde django için varsayılandır, ancak bazen değil.
dalore

2
Bu tehlikeli olabilir çünkü filtre boş bir liste döndürebilir
Kingston Chan

'-id' sırayı tersine çevirmek için kullanılır!
Indra

3
[0] yerine belki .first ()?
fevgenym

121

Django'daki belgelere bakın: https://docs.djangoproject.com/en/dev/ref/models/querysets/#latest

En geç () alanında bir alan belirtmeniz gerekiyor. Örneğin.

obj= Model.objects.filter(testfield=12).latest('testfield')

Veya modelinizin Meta'sı get_latest_by belirtiyorsa, field_nameargümanını devre dışı bırakabilirsiniz earliest() or latest(). Django get_latest_byvarsayılan olarak içinde belirtilen alanı kullanacaktır .


2
"Testfield" bir tarih alanı olmak zorunda mı?
tani-rokk


17

latestgerçekten tarih alanlarıyla çalışmak üzere tasarlanmıştır (muhtemelen diğer toplam sıralı türlerle de çalışır, ancak emin değildir). Ve alan adını belirtmeden kullanmanın tek yolu get_latest_by, burada belirtildiği gibi meta özelliğini ayarlamaktır .


8
Birincil anahtarlarla çalışır, her zaman şöyle bir şey yapabilirsiniz:Model.objects.latest('id')
Ander

6

obj= Model.objects.filter(testfield=12).order_by('-id')[:1] doğru çözüm


0

Bununla aşağıda karşılaştırma yapabilirsiniz.

görüntü

latest('created')ile aynıdır order_by('-created').first() Lütfen yanılıyorsam düzeltin

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.