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:utf8
from django.db import models
class Userlist(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-2 12:00')
TypeID = models.ForeignKey('UserType')
class UserType(models.Model):
name = models.CharField(max_length=50)
def __unicode__(self):
return self.name
这里UserType 返回的是name信息,是为了在后台管理界面中,在编辑Userlist表时,UserType字段显示UserType对象的name属性,即“管理员,超级管理员,普通用户”
admin.py代码:
from django.contrib import admin
from learn.models import *
# Register your models here.
class UserlistAdmin(admin.ModelAdmin):
list_display = ['username','password','Gender','Age','memo','TypeID']
admin.site.register(Userlist,UserlistAdmin)
class UserTypeAdmin(admin.ModelAdmin):
list_display = ['name','id']
admin.site.register(UserType,UserTypeAdmin)
这里UserType表显示了id字段,默认每张表都有id字段,并且是自增的。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。