![](/img/trans.png)
[英]Annotating a query with a values_list, using foreign key and many-to-many in Django
[英]django values_list of all fields in foreign key
我有一個類與另一個類的外鍵:
class MyEvent(models.Model):
msg = models.ForeignKey(MyMessage)
event_type = models.IntegerField(choices=EVENTS_TYPES)
class MyMessage(models.Model):
notification = models.IntegerField(choices=EVENTS_TYPES2)
name = models.CharField(max_length=20, null=False, blank=False)
description = models.CharField(max_length=150, null=False, blank=False)
的結果:
MyEvent.objects.all().values('msg','event_type')
是:
[{'msg': 18L,'event_type': 1L}, {'msg': 15L,'event_type': 2L}]
但是有可能獲得外鍵(MyMessage)對象的所有值嗎? (我想在沒有明確引用的情況下獲得。 - 不喜歡將'msg__description'添加到MyEvent.objects.all()。values('msg','event_type'))
我想要的結果是這樣的:
[{'msg': 18L,'msg__name': 'dd','msg__description': 'kkk','event_type': 1L}, {'msg': 15L,'msg__name': 'dd','msg__description': 'kkk','event_type': 2L}]
您可以在values函數中引用外鍵屬性:
MyEvent.objects.all().values('msg','event_type', 'msg__name', 'msg__description')
您可以使用基於MyMessage._meta
列表msg__
創建一個字段名稱列表,其中msg__
置於每個值。 然后使用.values(*list_of_fields)
解壓縮值。
除此之外,這是不可能的。 values()
只接受字段名作為位置參數,因此您必須在調用values()
之前隱式生成參數。
您應該像這樣向外鍵添加相關名稱
class MyEvent(models.Model):
msg = models.ForeignKey(MyMessage,related_name='message')
event_type = models.IntegerField(choices=EVENTS_TYPES)
class MyMessage(models.Model):
notification = models.IntegerField(choices=EVENTS_TYPES2)
name = models.CharField(max_length=20, null=False, blank=False)
related_name=description = models.CharField(max_length=150, null=False, blank=False)
然后您可以使用相關名稱檢索它。 像這樣:
objs=MyEvent.objects.all()
objs[0].message.all() # this is the Mymessage record
然后你可以隨意創建你的列表
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.