-1

MultipleChoiceField在我的测试服务器(使用 Apache)上保存 a 时遇到问题。但是,它适用于我的本地机器(django 服务器)。

在一个表格中,checkboxes我可以选中和取消选中。当我单击保存按钮时,与复选框相关的数据将保存在数据库中,并重新加载表单并更新复选框。

但是,这是它在本地而不是在测试服务器上的工作方式。在测试服务器上,当我单击保存按钮时,它只是重新加载表单,没有保存任何内容,没有任何更改。

这是代码:

class Participant(models.Model):
    databases = models.ManyToManyField(Advertiser, null=True, blank=True, through='ShareDataToBrands')

    @property
    def share_to_brands_list(self):
        brands=[]
        for brand in ShareDataToBrands.objects.all():
            brands.append((brand.advertiser.id, brand.advertiser.brand_name, brand.share_data))

        return brands

class ShareDataToBrandsForm(forms.ModelForm):
    class Meta:
        model = models.Participant
        fields = ('databases', )

    databases=forms.MultipleChoiceField(widget=forms.CheckboxSelectMultiple, required=False)

    def save(self, *args, **kwargs):
        instance=super(ShareDataToBrandsForm, self).save(commit=False)

        #list of brands to share data with
        share_list=map(int, self.cleaned_data.get("databases"))

        participant=self.instance
        for share_data_instance in models.ShareDataToBrands.objects.filter(participant=participant):
            if share_data_instance.advertiser.id in share_list:
                share_data=True
            else:
                share_data=False
            #update record
            share_data_instance.share_data=share_data
            share_data_instance.save()

        return instance

什么可能是错的?


编辑 :

当我检查时log,我看到程序永远不会进入for loop!但是,我在数据库中有与过滤器匹配的记录。

4

1 回答 1

0

我找到了解决方案,循环遍历ShareDataToBrands与参与者相关的实例而不是所有ShareDataToBrands实例。

share_to_brands_list属性中,更改了以下行:

for brand in ShareDataToBrands.objects.all():

for brand in ShareDataToBrands.objects.filter(participant=self):
于 2015-11-16T20:44:02.000 回答