如何将 NULL 插入 Django 的 DateField?



我的django模型中有一个可选的日期字段:

award_grant_date = models.DateField(null=True, blank=True)

当用户将日期字段留空时,将在DateField中插入NULL,否则将插入日期。

但是,如果用户确实在DateField中输入了一个日期,并且用户在表单中选择了一些其他特定的数据,那么我希望将NULL插入DateField。

因此,在我的表单中,我有以下代码:

    class AwardGrantDetailsForm(forms.Form):
    ...
    award_grant_date = forms.DateField(
    widget=forms.DateInput(attrs={'id':'id_award_grant_date'}),
    input_formats=settings.DATE_INPUT_FORMATS,
    label=_('Date'),
    required=False)
    ...
    elif cd_agdf['award_grant_type'] == 8888 or cd_agdf['award_grant_type'] == 9999:
        self.cleaned_data['award_grant_type_description'] = ''
        self.cleaned_data['award_grant_date'] = 'NULL' //this is the issue here! 

我得到的错误是:

[u"'NULL' value has an invalid date format. It must be in YYYY-MM-DD format."]

我似乎无法获得在award_grant_date日期字段中输入NULL的正确语法。

我使用的是bootstrap日期选择器和django 1.4。

如何编写self.cleaned_data['award_grant_date']=''代码以插入所需的NULL?我已将models字段设置为null=True,blank=True!

数据库null的Python表示为None:

self.cleaned_data['award_grant_date'] = None

NULL value has an invalid date format. It must be in YYYY-MM-DD format

如果要将Null值存储到模型中,请使用model_field=None

解决方案:

registration_date = request.POST.get('registration_date')
if not registration_date:
    registration_date = None
#StudentInfo is my model
student = StudentInfo(name=request.POST.get('name'), std=request.POST.get('std'), registration_date=registration_date)
#Now you can save your model data
student.save()

相关内容

  • 没有找到相关文章

最新更新