django外键使用 一对一

因为django中处于安全和方便将数据库中的表封装成模型,所以很多sql原生的功能无法使用, 比如 left join,但是我们可以使用外键(foreignkey)来满足表表直接的关系。
设置模型
# 在models.py 中添加
# Person 模型有两个外键, School和Province
#
class Province(models.Model):
name = models.CharField('省份', max_length = 10)
post = models.CharField('邮编', max_length = 10)
def __str__ (self):#在Python2中用__unicode__替换__str__
return self.name
# class School_Type(models.Model):
# school_type = models.CharField('学校类别')
class School(models.Model):
id = models.IntegerField('学校编号', primary_key=True)
name = models.CharField('学校名称', max_length=200)
address = models.CharField('学校地址', max_length=200)
def __str__ (self):#在Python2中用__unicode__替换__str__
return self.name
class Person(models.Model):
name = models.CharField('姓名', max_length=50)
age = models.IntegerField('年龄')
address = models.CharField('地址', max_length=100)
email = models.EmailField('电子邮件')
school = models.ForeignKey(School, on_delete=models.CASCADE)
province = models.ForeignKey(Province, on_delete = models.CASCADE)