簡體   English   中英

django values_list中的所有字段的外鍵

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM