Наборы запросов Django для поля многие-2-многие - PullRequest
0 голосов
/ 27 июня 2011

Я работаю над следующим:

# models.py

class FinancialProduct(models.Model):
    active = models.BooleanField(default=True)
    businesses = models.ManyToManyField(Business)
    name = models.CharField(max_length=40, unique=True)

class Item(models.Model):
    main_client = models.ForeignKey(Client)
    financial_product = models.ForeignKey(FinancialProduct)
    advisor = models.ForeignKey(User, blank=True, null=True)
    business = models.ForeignKey(Business)

class Business(models.Model):
    active = models.BooleanField(default=True)
    name = models.CharField(max_length=40, unique=True)

# forms.py

class ItemForm(ModelForm):

    def __init__(self,fpID,*args,**kwargs):
        super(ItemForm, self).__init__(*args, **kwargs)
        self.fields['advisor'].queryset = User.objects.filter(groups__name='advisor')
        self.fields['business'].queryset = Business.objects.filter(financialproduct__businesses=fpID)

    class Meta:
        model = Item
        exclude = ('main_client', 'financial_product')

    def CustomSave(self,f,c,u):
        idb = self.save(commit=False)
        idb.financial_product = f
        idb.main_client = c
        return idb.save()

И я создал следующие данные:

Business(1,'Company1')
Business(1,'Company2')
FinancialProduct(1,'Company1', 'Small Product')
FinancialProduct(1,'Company1,Company2', 'Large Product')

В интерфейсе я получаю следующее:

Select 'Small Product' > Get ('Company 1', 'Company 1', 'Company 2')
Select 'Large Product' > Get ('Company 1', 'Company 2')

К сожалению, я, кажется, неправильно получаю данные.Что я делаю не так с третьей строкой __init__?Это потому что это М2М?

Ответы [ 2 ]

1 голос
/ 27 июня 2011

Это неправильно:

FinancialProduct(1,'Company1,Company2', 'Large Product')

Вы сохраняете M2M с несколькими запросами.Скажи, как:

FinancialProduct(1,'Company1', 'Large Product').save()
FinancialProduct(1,'Company2', 'Large Product').save()
0 голосов
/ 27 июня 2011

Это абсолютно поджарило мою лапшу (потому что все это очень противоречит интуиции), но мне удалось придумать следующее.Надеюсь, это кому-нибудь поможет:

self.fields['business'].queryset = Business.objects.filter(financialproduct__id=fpID.id) 
...