时间:2021-05-23
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.nameclass 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)设置 ModelForm
因为Form的字段跟model的字段相同,所以我们直接使用 ModelForm, 使用ModelForm时外键会以 ChoiceField 字段来显示, 显示为 str()返回的字段
# 因为Form的字段跟model的字段相同,所以我们直接使用 ModelFormclass PersonForm(ModelForm): class Meta: model = Person fields = '__all__'保存
views.py 中的view,可以直接使用 form.save() 来保存formdef person(request): if request.POST: form = PersonForm(request.POST) if form.is_valid(): p = form.save() return HttpResponse(request, 'success') else: return HttpResponse(request, 'fail') else: form = PersonForm() person_list = Person.objects.all() # school_list = person_list.School_set.all() return render(request, 'person.html', locals())模版 person.html
可以在模版中使用 person.外键字段.外键表属性 来显示数据,比如 person.school.province.post
{% extends 'base.html' %}{% block content %} <form action="." method="POST"> {% csrf_token %} {{ form }} <input type="submit" value='submit' /> </form>{# #} {% for person in person_list %} <p>name:{{ person.name }}; age: {{ person.age }}; school:{{ person.school}} {{ person.province.post }} </p>{% endfor %}{# {{ school_list }}#}{% endblock %}以上这篇django foreignkey外键使用的例子 相当于left join就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言大家使用Django创建模型的时候一定会经常使用ForeignKey来创建两个表格之间多对一的外键关系,例如B中有一个models.ForeignKey(A
首先a++和++a的定义:看个例子 A:a=5;b=++a;//相当于a=a+1;b=a;结果是a=6,b=6 B:a=5;b=a++;//相当于b=a
django在使用外键ForeignKey的时候,会自动给当前字段后面添加一个后缀_id。正常来说这样并不会影响使用。除非你要写原生sql,还有就是这个表是已经
添加外键,altertableB 语法:altertable表名addconstraint外键约束名foreignkey(列名)references引用外
复制代码代码如下:functionaddEvent(obj,type,f