zoukankan      html  css  js  c++  java
  • luffy-课程表分析

    课程表分析

    course/models.py

    from django.db import models
    
    # Create your models here.
    # class Course(models.Model):
    #     name = models.CharField(max_length=64)
    #     title = models.CharField(max_length=64)
    #     level = models.IntegerField(choices=((0, '入门'), (1, '进阶')), default=0)
    #     detail = models.TextField()  # 可以关联详情表
    #     type = models.IntegerField(choices=((0, 'Python'), (1, 'Linux')), default=0)
    #     is_show = models.BooleanField(default=False)
    #
    #     # 优化字段
    #     # 记录学习课程的学生人数
    #     students = models.IntegerField(default=0)
    #     # time课程总学时
    #     time = models.IntegerField(default=0)
    #
    #     class Meta:
    #         abstract = True
    #
    #
    # # 免费课
    # class FreeCourse(Course):
    #     image = models.ImageField(upload_to='course/free')
    #     attachment = models.FileField(upload_to='attachment')
    #
    #
    # # 实战课
    # class ActualCourse(Course):
    #     image = models.ImageField(upload_to='course/actual')
    #     price = models.DecimalField(max_digits=7, decimal_places=2)
    #     # cost = models.DecimalField(max_digits=7, decimal_places=2)
    #
    #
    # # 轻课
    # class LightCourse(Course):
    #     image = models.ImageField(upload_to='course/light')
    #     price = models.DecimalField(max_digits=7, decimal_places=2)
    #     # cost = models.DecimalField(max_digits=7, decimal_places=2)
    #     period = models.IntegerField(verbose_name='学习建议周期(month)', default=0)
    
    # 评论表:分三个表、(id,ctx,date,user_id,free_course_id, comment_id)
    # 老师表:在课程表建立多对一外键
    # 章节表:在章节表建立多对一外键关联课程
    # 课时表:在课时表建立多对一外键关联章节
    
    from luffyapi.utils.models import BaseModel
    
    
    # 实际luffy中的表,免费课的
    class CourseCategory(BaseModel):
        """
        课程分类
        python,linux,go, 网络安全
        跟课程是一对多的关系
        """
        name = models.CharField(max_length=64, unique=True, verbose_name="分类名称")
    
        class Meta:
            db_table = "luffy_course_category"
            verbose_name = "分类"
            verbose_name_plural = verbose_name
    
        def __str__(self):
            return "%s" % self.name
    
    
    class Course(BaseModel):
        """课程"""
        course_type = (
            (0, '付费'),
            (1, 'VIP专享'),
            (2, '学位课程')
        )
        level_choices = (
            (0, '初级'),
            (1, '中级'),
            (2, '高级'),
        )
        status_choices = (
            (0, '上线'),
            (1, '下线'),
            (2, '预上线'),
        )
        # 原始字段
        name = models.CharField(max_length=128, verbose_name="课程名称")
        course_img = models.ImageField(upload_to="courses", max_length=255, verbose_name="封面图片", blank=True, null=True)
        course_type = models.SmallIntegerField(choices=course_type, default=0, verbose_name="付费类型")
        # 使用这个字段的原因
        brief = models.TextField(max_length=2048, verbose_name="详情介绍", null=True, blank=True)
        level = models.SmallIntegerField(choices=level_choices, default=0, verbose_name="难度等级")
        pub_date = models.DateField(verbose_name="发布日期", auto_now_add=True)
        period = models.IntegerField(verbose_name="建议学习周期(day)", default=7)
        attachment_path = models.FileField(upload_to="attachment", max_length=128, verbose_name="课件路径", blank=True,
                                           null=True)
        status = models.SmallIntegerField(choices=status_choices, default=0, verbose_name="课程状态")
        price = models.DecimalField(max_digits=6, decimal_places=2, verbose_name="课程原价", default=0)
    
        # 优化字段
        students = models.IntegerField(verbose_name="学习人数", default=0)
        sections = models.IntegerField(verbose_name="总课时数量", default=0)
        pub_sections = models.IntegerField(verbose_name="课时更新数量", default=0)
    
        # 关联字段
        teacher = models.ForeignKey("Teacher", on_delete=models.DO_NOTHING, null=True, blank=True, verbose_name="授课老师",
                                    db_constraint=False)
        course_category = models.ForeignKey("CourseCategory", on_delete=models.SET_NULL, db_constraint=False, null=True,
                                            blank=True, verbose_name="课程分类")
    
        class Meta:
            db_table = "luffy_course"
            verbose_name = "课程"
            verbose_name_plural = "课程"
    
        def __str__(self):
            return "%s" % self.name
    
        @property
        def course_type_name(self):
            return self.get_course_type_display()
    
        @property
        def level_name(self):
            return self.get_level_display()
    
        @property
        def status_name(self):
            return self.get_status_display()
    
        @property
        def section_list(self):
            ll = []
            # 根据课程取出所有章节(正向查询,字段名.all())
            course_chapter_list = self.coursechapters.all()
            for course_chapter in course_chapter_list:
                # 通过章节对象,取到章节下所有的课时(反向查询)
                # course_chapter.表名小写_set.all() 现在变成了course_chapter.coursesections.all()
                course_sections_list = course_chapter.coursesections.all()
                for course_section in course_sections_list:
                    ll.append({
                        'name': course_section.name,
                        'section_link': course_section.section_link,
                        'duration': course_section.duration,
                        'free_trail': course_section.free_trail,
                    })
                    if len(ll) >= 4:
                        return ll
    
            return ll
    
    
    class Teacher(BaseModel):
        """
        导师
        跟课程一对多,关联字段写在课程表中
        """
        role_choices = (
            (0, '讲师'),
            (1, '导师'),
            (2, '班主任'),
        )
        name = models.CharField(max_length=32, verbose_name="导师名")
        role = models.SmallIntegerField(choices=role_choices, default=0, verbose_name="导师身份")
        title = models.CharField(max_length=64, verbose_name="职位、职称")
        signature = models.CharField(max_length=255, verbose_name="导师签名", help_text="导师签名", blank=True, null=True)
        image = models.ImageField(upload_to="teacher", null=True, verbose_name="导师封面")
        brief = models.TextField(max_length=1024, verbose_name="导师描述")
    
        class Meta:
            db_table = "luffy_teacher"
            verbose_name = "导师"
            verbose_name_plural = verbose_name
    
        def __str__(self):
            return "%s" % self.name
    
        def role_name(self):
            # 返回角色的中文
            return self.get_role_display()
    
    
    class CourseChapter(BaseModel):
        """
        章节
        章节跟课程是一(课程)对多(章节多)
        """
        course = models.ForeignKey("Course", related_name='coursechapters', on_delete=models.CASCADE, verbose_name="课程名称",
                                   db_constraint=False)
        chapter = models.SmallIntegerField(verbose_name="第几章", default=1)
        name = models.CharField(max_length=128, verbose_name="章节标题")
        summary = models.TextField(verbose_name="章节介绍", blank=True, null=True)
        pub_date = models.DateField(verbose_name="发布日期", auto_now_add=True)
    
        class Meta:
            db_table = "luffy_course_chapter"
            verbose_name = "章节"
            verbose_name_plural = verbose_name
    
        def __str__(self):
            return "%s:(第%s章)%s" % (self.course, self.chapter, self.name)
    
    
    class CourseSection(BaseModel):
        """
        课时
            章节和课时是一对多的关系,关联字段写在多的一方,课时
        """
        section_type_choices = (
            (0, '文档'),
            (1, '练习'),
            (2, '视频')
        )
        chapter = models.ForeignKey("CourseChapter", related_name='coursesections', on_delete=models.CASCADE,
                                    verbose_name="课程章节", db_constraint=False)
        name = models.CharField(max_length=128, verbose_name="课时标题")
        orders = models.PositiveSmallIntegerField(verbose_name="课时排序")
        section_type = models.SmallIntegerField(default=2, choices=section_type_choices, verbose_name="课时种类")
        section_link = models.CharField(max_length=255, blank=True, null=True, verbose_name="课时链接",
                                        help_text="若是video,填vid,若是文档,填link")
        duration = models.CharField(verbose_name="视频时长", blank=True, null=True, max_length=32)  # 仅在前端展示使用
        pub_date = models.DateTimeField(verbose_name="发布时间", auto_now_add=True)
        free_trail = models.BooleanField(verbose_name="是否可试看", default=False)
    
        class Meta:
            db_table = "luffy_course_Section"
            verbose_name = "课时"
            verbose_name_plural = verbose_name
    
        def __str__(self):
            return "%s-%s" % (self.chapter, self.name)

    基表utils/models.py

    from django.db import models
    
    
    # 后期课程表,轮播图表,都会用到这些字段
    
    class BaseModel(models.Model):
        is_delete = models.BooleanField(default=False, verbose_name='是否删除')
        is_show = models.BooleanField(default=True, verbose_name='是否展示')
        created_time = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')
        updated_time = models.DateTimeField(auto_now=True, verbose_name='最后更新时间')
        orders = models.IntegerField()
    
        class Meta:
            abstract = True  # 一定不要忘了

    数据迁移

    # python manage.py makemigrations
    # python manage.py migrate

    注册models:course/adminx.py

    import xadmin
    from . import models
    
    xadmin.site.register(models.CourseCategory)
    xadmin.site.register(models.Course)
    xadmin.site.register(models.Teacher)
    xadmin.site.register(models.CourseChapter)
    xadmin.site.register(models.CourseSection)
  • 相关阅读:
    MySQL多实例配置
    MySQL8.0启动和关闭流程
    MySQL8.0初始化配置方式 ——维护使用
    MySQL多种连接方式
    MySQL 8.0用户及安全管理
    MySQL 5.7安装及版本升级到8.0
    五十六、linux 编程——UDP 编程模型
    五十五、linux 编程——TCP 连接和关闭过程及服务器的并发处理
    五十四、linux 编程——TCP 编程模型
    五十三、linux 编程——TCP 编程基本介绍
  • 原文地址:https://www.cnblogs.com/baicai37/p/13387726.html
Copyright © 2011-2022 走看看