视图.py
def addbook(request):
if request.POST:
book_form = BookForm(request.POST)
author_form = AuthorForm(request.POST)
if (book_form.is_valid() and author_form.is_valid()):
log.debug("test....")
book=book_form.save()
author=author_form.save()
author.book=book
author.save()
return redirect('/index/')
else:
book_form=BookForm()
author_form=AuthorForm()
return render_to_response('addbook.html',{'form':book_form,'form':author_form},context_instance=RequestContext(request))
表格.py
from django import forms
from django.forms import ModelForm
from myapp.models import Book,Author
class AuthorForm(ModelForm):
class Meta:
model = Author
fields=['author_id','first_name','last_name','email','age']
class BookForm(ModelForm):
class Meta:
model = Book
fields=['book_id','book_name','publisher_name','author']
模型.py
from django.db import models
class Author(models.Model):
author_id = models.AutoField(primary_key=True)
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=40)
email = models.EmailField()
age=models.IntegerField()
class Meta:
db_table=u'Author'
def __unicode__(self):
return u"%d %s %s %s %d" % (self.pk, self.first_name, self.last_name, self.email,self.age)
class Book(models.Model):
book_id=models.AutoField(primary_key=True,unique=True)
book_name=models.CharField(max_length=30)
publisher_name=models.CharField(max_length=40)
author=models.ForeignKey(Author)
class Meta:
db_table = u'Book'
def __unicode__(self):
return u'%d %s %s' % (self.pk, self.book_name, self.publisher_name)
模板.html
<div align="center">
<form action="/addbook/" method="post">
{% csrf_token %}
{{ book_form.as_p }}
{{ author_form.as_p }}
<input type="submit" value="submit">
</form>
在这里,我使用作者作为 foriegnkey。在表单中,我已经为数据库中的所有字段提供了字段。当我单击提交按钮时,它会显示字段以及作者字段。这里 author 表中的 author_id 指向 book 表中的 author_id。在 views.py 中我们如何实现它。
我希望以这种方式将数据保存到数据库中。我也更改了我的模板。