Django model.save()没有写入数据库

时间:2012-06-28 19:05:32

标签: database django save django-forms

我是Django的新手,只是尝试使用ModelForms提交表单来创建新事件并将其保存到数据库中。

我正在尝试将行插入三个表:Location,Event(具有location_id FK)和EventSchedule(作为event_id FK)。

以下是保存表单的方法。调用它时,不会返回任何错误,但新行不会插入到数据库中。:

addNewEvent()(在views.py中)

def addNewEvent(self, event_form, location_form, event_sched_form, latitude, longitude):

    new_event = event_form.save(commit=False)
    new_location = location_form.save(commit=False)
    new_event_sched = event_sched_form.save(commit=False)
    # set any necessary values and save forms
    new_location.latitude = latitude
    new_location.longitude = longitude
    new_location.save()
    new_event.flagged = False
    new_event.location = new_location
    new_event.save()
    new_event_sched.event = new_event
    new_event_sched.save()

models.py

class Location(models.Model):
    name = models.CharField(max_length=200)
    #address = models.CharField(max_length=200)
    city = models.CharField(max_length=200)
    state_code = models.CharField(max_length=100)
    zip = models.CharField(max_length=100, blank=True)
    country = models.CharField(max_length=100)
    latitude = models.DecimalField(max_digits=9, decimal_places=6)
    longitude = models.DecimalField(max_digits=9, decimal_places=6)
    class Meta:
        db_table = 'location'

class Event(models.Model):
    CATEGORIES = (
        ('KID', 'Kids'),
        ('FAM', 'Family'),
        ('NIT', 'Nightlife'),
        ('OUT', 'Outdoors'),
        ('ART', 'Arts'),
        ('MSC', 'Music'),
        ('SPT', 'Sports'),
        ('SAL', 'Sale'),
        ('EDU', 'Educational'),
        ('POL', 'Political'),
        ('FOD', 'Food'),
        ('OTH', 'Other')
    )
    location = models.ForeignKey(Location)
    name = models.CharField(max_length=200)
    description = models.CharField(max_length=200)
    category = models.CharField(max_length=20, choices=CATEGORIES)
    age_req = models.IntegerField(null=True)
    cost_per_person = models.DecimalField(max_digits=5, decimal_places=2, null=True)
    flagged = models.BooleanField()
    users = models.ManyToManyField(User, through='UserEvent')
    class Meta:
        db_table = 'event'

class EventSchedule(models.Model):
    event = models.ForeignKey(Event)
    start_date_time = models.DateTimeField()
    end_date_time = models.DateTimeField()
    class Meta:
        db_table = 'event_schedule'

forms.py

来自django.forms导入ModelForm,表单 从模型导入事件,位置,EventSchedule

class EventForm(ModelForm):
    class Meta:
        model = Event
        fields = ('name','description','category','age_req','cost_per_person')

class LocationForm(ModelForm):
    class Meta:
        model = Location
        fields = ('name','city','state_code','zip','country')

class EventScheduleForm(ModelForm):
    class Meta:
        model = EventSchedule
        fields = ('start_date_time', 'end_date_time')

非常感谢任何帮助。

谢谢,

彼得

修改

我甚至无法保存模型,更不用说ModelForm了(即使我在其他地方成功完成)。我添加了以下代码以将用户与事件相关联。没有错误,但它没有向数据库添加行:

new_user_event = UserEvent(user=user,
                                event=new_event,
                                datetime_created=datetime.datetime.now())
new_user_event.save()

有什么想法吗?

编辑2:

new_user_event的屏幕截图:http://imgur.com/JUauG

编辑3:

这就是我实例化ModelForms的方式:

event_form = EventForm(request.POST or None)
location_form = LocationForm(request.POST or None)
event_sched_form = EventScheduleForm(request.POST or None)

3 个答案:

答案 0 :(得分:19)

哇,我是个白痴。在我实际显示事件之前,我正在删除表中的行,因为某些代码用虚拟数据填充了数据库。

我可以删除这个问题,还是应该将其作为我愚蠢的证明?

答案 1 :(得分:1)

答案 2 :(得分:0)

你没有在这里发布最重要的部分IHMO:你的表格是如何实现的? ModelForm可用于创建新实例或更新现有实例。如果您将现有实例传递给表单,那么您的代码将只更新它们。