您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
我现在有的表结构是班级表,课程表,
班级表的主要结构如下
课程名称 | 学 期 | 校 区 | 任课老师 s |
---|---|---|---|
class_title | time | campuses | teachers |
表结构中:
class_title,time,campusees必须设置联合唯一,
所以在django中的modes.py 文件中设置如下
from django.db import models
class ClassList(models.Model):
"""
班级表
"""
course = models.CharField("课程名称", max_length=64, choices=course_choices)
semester = models.IntegerField("学期")
campuses = models.ForeignKey('Campuses', verbose_name="校区")
teachers = models.ManyToManyField('UserProfile', verbose_name="老师")
class Meta:
unique_together = ("course", "semester", 'campuses')
课程表的主要结构如下
班 级 | 授课内容 | 节 次 | 授课时间 | 班主任 |
---|---|---|---|---|
re_class | content | day_num | date | b_teacher |
设置class与date_num为联合唯一,保证一个班级一天只能上一节课
class CourseRecord(models.Model):
"""课程记录表"""
day_num = models.IntegerField("节次", help_text="此处填写第几节课或第几天课程...,必须为数字")
date = models.DateField(auto_now_add=True, verbose_name="上课日期")
course_title = models.CharField('本节课程标题', max_length=64, blank=True, null=True)
re_class = models.ForeignKey('ClassList', verbose_name="班级")
teacher = models.ForeignKey('UserProfile', verbose_name="班主任")
class Meta:
unique_together = ('re_class', 'day_num')
如何保证同一个老师不会被’分身‘??
如:
python-1期-海南 3-31 第一节 penny老师
python-2期-上海 3-31 第一节 penny老师
方法一重新建表结构:
班 级 | 授课内容 | 节 次 | 授课时间 | 班主任 | 授课教师 |
---|---|---|---|---|---|
re_class | content | day_num | date | b_teacher | teacher |
将节次,授课时间,授课老师设为联合唯一
而已经设置class与date_num为联合唯一
这可就出现了俩个联合唯一的问题了???
class Meta:
unique_together = [('re_class', 'day_num'), ('date', 'day_num', 'teacher')]
]
但是:
虽然可以限制,但是会出现飘页面错误的问题!!!!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。