django ForeignKey的使用
ForeignKey,ManyToManyField与OneToOneField分别在Model中定义多对一,多对多,一对一关系。
ForeignKey
加入数据库中要建立两张表,userlist和UserTpye。
Userlist表的字段有
['username','password','Gender','Age','memo','TypeID']
UserType表的字段有
['name]
这里的name值只有三个,管理员,超级管理员,普通用户。
现在希望Userlist和UserType两张表关联起来,即Userlist中有一个TypeID的字段,其值为UserType表的限定的三个值。也就是说Userlist中TypeID只能为管理员、超级管理员或者普通用户
#coding:utf8fromdjango.dbimportmodelsclassUserlist(models.Model):username=models.CharField(max_length=50)password=models.CharField(max_length=50)male={('man',u'男'),('woman',u'女'),}Gender=models.CharField(max_length=50,blank=True,choices=male)Age=models.IntegerField(default='20')memo=models.TextField(default='xxx')#CreateDate=models.DateTimeField(default='2012-1-212:00')TypeID=models.ForeignKey('UserType')classUserType(models.Model):name=models.CharField(max_length=50)def__unicode__(self):returnself.name
这里UserType 返回的是name信息,是为了在后台管理界面中,在编辑Userlist表时,UserType字段显示UserType对象的name属性,即“管理员,超级管理员,普通用户”
admin.py代码:
fromdjango.contribimportadminfromlearn.modelsimport*#Registeryourmodelshere.classUserlistAdmin(admin.ModelAdmin):list_display=['username','password','Gender','Age','memo','TypeID']admin.site.register(Userlist,UserlistAdmin)classUserTypeAdmin(admin.ModelAdmin):list_display=['name','id']admin.site.register(UserType,UserTypeAdmin)
这里UserType表显示了id字段,默认每张表都有id字段,并且是自增的。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。