ORM中choices参数(重要)、MTV于MVC模型、多对多关系三种创建方式
choices参数(重要)
使用方式 :
只要某个字段的可能性是可以列举完全的,那么一般情况下都会采用choices参数
eg:
一张用户表
性别
学历
工作经验
是否结婚
是否生子
客户来源
...
针对某个可以列举完全的可能性字段,我们应该如何存储?
choice使用方法
class User(models.Model):
name = models.CharField(max_length=32)
age = IntegerField()
**************************choice用法***************************
# 性别
sex_choices = ( # 格式: 必须用元组套元组的形式
(1, '男') # 而且小元组里第一个元素必须符合下面创建的字段类型
(2, '女')
(3, '其他')
)
sex = models.IntegerField(choices=sex_choices)
取:
# 先添加数据
models.User.objects.create(name='jason', age=18, sex=1)
models.User.objects.create(name='kevin', age=20, sex=2)
models.User.objects.create(name='tony', age=22, sex=3)
models.User.objects.create(name='egon', age=24, sex=4)
# 读取数据
user_list = models.User.objects.all()
for user_obj in user_list:
print(user_obj.get_sex_display()) # get_字段名_display()是固定句式
score_choices = (
('A','优秀'),
('B','良好'),
('C','及格'),
('D','不合格'),
)
# 保证字段类型跟列举出来的元祖第一个数据类型一致即可
score = models.CharField(choices=score_choices,null=True)
相似案例
class Customer(models.Model):
"""
客户表
"""
qq = models.CharField(verbose_name='qq', max_length=64, unique=True, help_text='QQ号必须唯一')
name = models.CharField(verbose_name='学生姓名', max_length=16)
gender_choices = ((1, '男'), (2, '女'))
gender = models.SmallIntegerField(verbose_name='性别', choices=gender_choices)
education_choices = (
(1, '重点大学'),
(2, '普通本科'),
(3, '独立院校'),
(4, '民办本科'),
(5, '大专'),
(6, '民办专科'),
(7, '高中'),
(8, '其他')
)
education = models.IntegerField(verbose_name='学历', choices=education_choices, blank=True, null=True, )
graduation_school = models.CharField(verbose_name='毕业学校', max_length=64, blank=True, null=True)
major = models.CharField(verbose_name='所学专业', max_length=64, blank=True, null=True)
experience_choices = [
(1, '在校生'),
(2, '应届毕业'),
(3, '半年以内'),
(4, '半年至一年'),
(5, '一年至三年'),
(6, '三年至五年'),
(7, '五年以上'),
]
experience = models.IntegerField(verbose_name='工作经验', blank=True, null=True, choices=experience_choices)
work_status_choices = [
(1, '在职'),
(2, '无业')
]
work_status = models.IntegerField(verbose_name="职业状态", choices=work_status_choices, default=1, blank=True,
null=True)
company = models.CharField(verbose_name="目前就职公司", max_length=64, blank=True, null=True)
salary = models.CharField(verbose_name="当前薪资", max_length=64, blank=True, null=True)
source_choices = [
(1, "qq群"),
(2, "内部转介绍"),
(3, "官方网站"),
(4, "百度推广"),
(5, "360推广"),
(6, "搜狗推广"),
(7, "腾讯课堂"),
(8, "广点通"),
(9, "高校宣讲"),
(10, "渠道代理"),
(11, "51cto"),
(12, "智汇推"),
(13, "网盟"),
(14, "DSP"),
(15, "SEO"),
(16, "其它"),
]
source = models.SmallIntegerField('客户来源', choices=source_choices, default=1)
referral_from = models.ForeignKey(
'self',
blank=True,
null=True,
verbose_name="转介绍自学员",
help_text="若此客户是转介绍自内部学员,请在此处选择内部学员姓名",
related_name="internal_referral"
)
course = models.ManyToManyField(verbose_name="咨询课程", to="Course")
status_choices = [
(1, "已报名"),
(2, "未报名")
]
status = models.IntegerField(
verbose_name="状态",
choices=status_choices,
default=2,
help_text=u"选择客户此时的状态"
)
consultant = models.ForeignKey(verbose_name="课程顾问", to='UserInfo', related_name='consultanter',limit_choices_to={'depart':1001})
date = models.DateField(verbose_name="咨询日期", auto_now_add=True)
recv_date = models.DateField(verbose_name="当前课程顾问的接单日期", null=True)
last_consult_date = models.DateField(verbose_name="最后跟进日期", )
def __str__(self):
return self.name
MTV与MVC模型
# MTV:Django号称是MTV模型
M:models
T:templates
V:views
# MVC:其实django本质也是MVC
M:models
V:views
C:controller
# vue框架:MVVM模型
多对多三种创建方式
半自动 | 全自动 | 纯手动 |
---|---|---|
优点:可以使用orm的正反向查询,并且第三张表的扩展性高 | 优点: 代码不需要自己写,方便,还支持orm提供操作第三张关系表的方法 | 优点: 第三张表完全取决你自己进行额外的扩展 |
缺点: 没办法使用add,set,remove,clear这四个方法 | 缺点: 第三张关系表的扩展性极差(没办法额外添加字段) | 缺点: 需要写的代码较多,不能够再使用orm提供的简单的方法 |
半自动(必须掌握)
需要手动创建第三张表
class Book(models.Model):
title = models.CharField(max_length=32, verbose_name='书名')
authors = models.ManyToManyField(to='Author',
through='BookToAuthor', # 告诉ORM我的第三张表是谁
through_fields=('book', 'author')) # 告诉ORM是通过那两个字段建立关系的
# 因为第三张表有可能还有其他的外籍那字段,所以要指明
class Author(models.Model):
name = models.CharField(max_length=32, verbose_name='姓名')
class BookToAuthor(models.Model):
book = models.ForeignKey(to='Book')
author = models.ForeignKey(to='Author')
# 注意: through_fields字段先后顺序,当前表是谁 就把对应的关联字段放前面,如果上面的外键字段是在作者表里创建的,那么throuth_field元组里的参数要调换位置through_fields=('author', 'book')) 就可以了
全自动(熟练)
利用orm帮我们创建第三张关系表
class Book(models.Model):
title = models.CharField(max_length=32, verbose_name='书名')
authors = models.ManyToManyField(to='Author')
class Author(models.Model):
name = models.CharField(max_length=32, verbose_name='姓名')
# 第三张关系表ORM会自动帮我们创建
纯手动(了解)
需要手动创建第三张表
class Book(models.Model):
title = models.CharField(max_length=32, verbose_name='书名')
authors = models.ManyToManyField(to='Author')
class Author(models.Model):
name = models.CharField(max_length=32, verbose_name='姓名')
# 手动创建
class BookToAuthor(models.Model):
book_id = models.ForeignKey(to='Book')
author_id = models.ForeignKey(to='Author')
总结
需要掌握的是全自动和半自动 为了扩展性更高 一般我们都会采用半自动(写代码要给自己留一条后路)