需求

用户角色,讲师\学员, 用户登陆后根据角色不同,能做的事情不同,分别如下

讲师视图

  管理班级,可创建班级,根据学员qq号把学员加入班级

  可创建指定班级的上课纪录,注意一节上课纪录对应多条学员的上课纪录, 即每节课都有整班学员上, 为了纪录每位学员的学习成绩,需在创建每节上课纪录是,同时 为这个班的每位学员创建一条上课纪录

  为学员批改成绩, 一条一条的手动修改成绩

学员视图

提交作业

查看作业成绩

一个学员可以同时属于多个班级,就像报了Linux的同时也可以报名Python一样, 所以提交作业时需先选择班级,再选择具体上课的节数

附加:学员可以查看自己的班级成绩排名

表结构

部分代码

from sqlalchemy import create_engine,Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import ForeignKey,Table
from sqlalchemy.orm import relationship ############创建数据表结构######################3
# 创建实例,并连接work库
engine = create_engine("mysql+pymysql://root:@localhost/home_work?charset=utf8")
Base = declarative_base() # 生成orm基类 # 班级与讲师的对应关系表
teacher_m2m_class = Table("teacher_m2m_class",Base.metadata,
Column("teacher_id", Integer, ForeignKey("teacher.teacher_id")),
Column("class_id", Integer, ForeignKey("class.class_id")),
) # 班级与学生的对应关系表
class_m2m_student = Table("class_m2m_student",Base.metadata,
Column("class_id",Integer,ForeignKey("class.class_id")),
Column("stu_id", Integer, ForeignKey("student.stu_id")),
) class Class_m2m_Lesson(Base):
'''班级和课节对应表'''
__tablename__ = "class_m2m_lesson"
id = Column(Integer, primary_key=True)
class_id = Column(Integer,ForeignKey("class.class_id"))
lesson_id = Column(Integer, ForeignKey("lesson.lesson_id")) classes = relationship("Class",backref="class_m2m_lessons")
lessons = relationship("Lesson", backref="class_m2m_lessons") def __repr__(self):
return "%s %s" % (self.classes,self.lessons) class Study_record(Base):
"上课记录"
__tablename__ = "study_record"
id = Column(Integer,primary_key=True)
class_m2m_lesson_id = Column(Integer,ForeignKey("class_m2m_lesson.id"))
stu_id = Column(Integer, ForeignKey("student.stu_id"))
status = Column(String(32),nullable=False)
score = Column(Integer,nullable=True) class_m2m_lessons = relationship("Class_m2m_Lesson",backref="my_study_record")
students = relationship("Student", backref="my_study_record") def __repr__(self):
return "\033[35;0m%s,%s,状态:【%s】,成绩:【%s】\33[0m"%(self.class_m2m_lessons,self.students,self.status,self.score) class Teacher(Base):
"讲师"
__tablename__ = "teacher"
teacher_id = Column(Integer, primary_key=True)
teacher_name = Column(String(32), nullable=False, unique=True) #唯一 classes = relationship("Class", secondary=teacher_m2m_class, backref="teachers") def __repr__(self):
return "讲师:【%s】"%self.teacher_name class Class(Base):
"班级"
__tablename__ ="class"
class_id = Column(Integer, primary_key=True)
class_name = Column(String(32), nullable=False,unique=True)
course = Column(String(32), nullable=False) students = relationship("Student",secondary=class_m2m_student,backref="classes") def __repr__(self):
return "班级名:【%s】"%self.class_name class Student(Base):
"学生"
__tablename__ ="student"
stu_id = Column(Integer, primary_key=True)
stu_name = Column(String(32), nullable=False, unique=True)
QQ = Column(Integer(), nullable=False) def __repr__(self):
return "学生名:【%s】"%self.stu_name class Lesson(Base):
"课节"
__tablename__ = "lesson"
lesson_id = Column(Integer, primary_key=True)
lesson_name = Column(String(32), nullable=False, unique=True) def __repr__(self):
return "节次名:【%s】"%self.lesson_name Base.metadata.create_all(engine)

表结构

from sqlalchemy import desc
from .models import Teacher,Class,Student,Lesson,Class_m2m_Lesson,Study_record
import random class Student_Center(object):
"学生视图"
def __init__(self,session):
self.session = session
self.authentication()
self.handler() def handler(self):
while True:
print('''\n\33[35;1m———欢迎来【%s】进入学员管理系统————\33[0m \n
\33[34;0mup_homework 上传作业
show_homework 查看作业成绩
show_rank 查看班级排名
exit 退出管理系统
\33[0m''' % self.student_obj.stu_name)
user_func = input("\033[34;0m请输入进行操作的命令:\033[0m").strip()
if hasattr(self, user_func):
getattr(self, user_func)() def authentication(self):
'''认证'''
while True:
student_name = input("\033[34;0m请输入学生名:\033[0m").strip()
self.student_obj = self.session.query(Student).filter_by(stu_name=student_name).first()
if not self.student_obj:
print("\33[31;1m输入错误:请输入有效的学生名\33[0m")
continue
else:
# print(self.teacher_obj)
break def up_homework(self):
"上传作业"
class_name = input("\033[34;0m请输入班级名:\033[0m") for class_obj in self.student_obj.classes:
print(class_obj.class_name)
if class_name == class_obj.class_name:
lesson_name = input("\033[34;0m请输入的课节名(lesson):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first() if lesson_obj: # 输入的lesson名字存在
class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(
Class_m2m_Lesson.class_id == class_obj.class_id). \
filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first()
if class_m2m_lesson_obj: # 班级对应的课lesson表数据存在
study_record_obj = self.session.query(Study_record).filter(
Study_record.class_m2m_lesson_id == class_m2m_lesson_obj.id).filter(
Study_record.stu_id == self.student_obj.stu_id).first() if study_record_obj: # 上课记录存在
score = random.randint(10,100)
study_record_obj.score = score
self.session.commit()
print("上传成功")
else:
print("\33[31;1m系统错误:当前上课记录已经创建\33[0m")
else:
print("\33[31;1m系统错误:lesson未创建\33[0m") def show_homework(self):
'''查看作业成绩'''
class_name = input("\033[34;0m请输入学习记录的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj:
lesson_name = input("\033[34;0m请输入学习记录的课节名(lesson):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first() if lesson_obj: # 输入的lesson名字存在
class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(
Class_m2m_Lesson.class_id == class_obj.class_id). \
filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first() if class_m2m_lesson_obj: # 班级对应的课lesson表数据存在
study_record_objs = self.session.query(Study_record).filter(
Study_record.class_m2m_lesson_id == class_m2m_lesson_obj.id).all()
for obj in study_record_objs:
if obj.stu_id == self.student_obj.stu_id:
print(obj) def show_rank(self):
'''查看排名''' class_name = input("\033[34;0m请输入学习记录的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj:
lesson_name = input("\033[34;0m请输入学习记录的课节名(lesson):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first() if lesson_obj: # 输入的lesson名字存在
class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(
Class_m2m_Lesson.class_id == class_obj.class_id). \
filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first() if class_m2m_lesson_obj: # 班级对应的课lesson表数据存在
score_rank_obj = self.session.query(Study_record).order_by(desc(Study_record.score))
for obj in score_rank_obj:
if obj.class_m2m_lesson_id == class_m2m_lesson_obj.id:
print(obj)

学生视图

from .models import Teacher,Class,Student,Lesson,Class_m2m_Lesson,Study_record,class_m2m_student

class  Teacher_Center(object):
"讲师视图"
def __init__(self,session):
self.session = session
self.authentication()
self.handler() def handler(self):
while True:
print('''\n\33[35;1m———欢迎来【%s】进入讲师管理系统————\33[0m \n
\33[34;0mshow_classes 显示可管理的班级
add_class 创建班级
add_student 添加学员
add_lesson 添加课程节次
add_studyrecord 创建上课记录
modify_scores 修改学员成绩
exit 退出管理系统
\33[0m''' % self.teacher_obj.teacher_name)
user_func = input("\033[34;0m请输入进行操作的命令:\033[0m").strip()
if hasattr(self, user_func):
getattr(self, user_func)() def authentication(self):
'''认证'''
while True:
teacher_name = input("\033[34;0m请输入讲师名:\033[0m").strip()
self.teacher_obj = self.session.query(Teacher).filter_by(teacher_name=teacher_name).first()
if not self.teacher_obj:
print("\33[31;1m输入错误:请输入有效的讲师名\33[0m")
continue
else:
#print(self.teacher_obj)
break def add_class(self):
'''创建班级'''
class_name = input("\033[34;0m请输入创建班级的名称:\033[0m")
course = input("\033[34;0m请输入创建班级的类型:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first()
if not class_obj:
class_new = Class(class_name=class_name,course=course)
self.teacher_obj.classes.append(class_new)
self.session.add(class_new)
self.session.commit()
print("\033[34;1m班级创建成功\033[0m")
else:
print("\33[31;1m系统错误:班级已经存在\33[0m") def show_classes(self):
'''查看所有的班级'''
print(self.teacher_obj)
for class_obj in self.teacher_obj.classes:
print("讲师:【%s】\t班级:【%s】\t类型:【%s】" % (class_obj.teachers[0].teacher_name,
class_obj.class_name,class_obj.course)) def add_student(self):
'''添加学员'''
class_name = input("\033[34;0m请输入要添加学员的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj and class_obj.teachers[0] == self.teacher_obj:
stu_name = input("\033[34;0m请输入学员的姓名:\033[0m")
QQ = input("\033[34;0m请输入学员的QQ号:\033[0m")
student_obj = self.session.query(Student).filter_by(QQ = QQ).first() if student_obj:
if student_obj.stu_name not in class_obj.students:
class_obj.students.append(student_obj)
self.session.add(class_obj)
self.session.commit()
print("\033[34;1m学员添加成功\033[0m")
else:
print("\33[31;1m系统错误:学员已经存在此班中\33[0m") elif not student_obj:
student_new = Student(stu_name=stu_name, QQ=QQ)
class_obj.students.append(student_new)
self.session.add(student_new)
self.session.commit()
print("\033[34;1m学员添加成功\033[0m")
else:
print("\33[31;1m系统错误:学员已经存在\33[0m")
else:
print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m") def add_lesson(self):
'''添加课程节次'''
class_name = input("\033[34;0m请输入要添加lesson的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj and class_obj.teachers[0] == self.teacher_obj: #输入的班级名存在且在属于当前老师管理
lesson_name = input("\033[34;0m请输入添加的lesson名(类day1):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()
if not lesson_obj: #输入的lesson名字不存在
print("lesson 不存在")
lesson_obj = Lesson(lesson_name=lesson_name) #增加lesson表数据
self.session.add(lesson_obj)
self.session.commit() rest = self.session.query(Class_m2m_Lesson).filter(Class_m2m_Lesson.class_id==class_obj.class_id).\
filter(Class_m2m_Lesson.lesson_id==lesson_obj.lesson_id).first()
if not rest: #如果class_m2m_lesson没有存储班级和课节的对应关系
print("class:%s----lesson:%s"%(class_obj.class_id,lesson_obj.lesson_id))
class_m2m_lesson_new = Class_m2m_Lesson(class_id=class_obj.class_id,lesson_id=lesson_obj.lesson_id)
self.session.add(class_m2m_lesson_new) #创建class_m2m_lesson对应关系
self.session.commit() else:
print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m") def add_studyrecord(self):
'''添加学习记录'''
class_name = input("\033[34;0m请输入要添加学习记录的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj and class_obj.teachers[0] == self.teacher_obj: # 输入的班级名存在且在属于当前老师管理
lesson_name = input("\033[34;0m请输入添加学习记录的课节名(lesson):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()
if lesson_obj: # 输入的lesson名字存在
class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(Class_m2m_Lesson.class_id == class_obj.class_id). \
filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first()
if class_m2m_lesson_obj: # 班级对应的课lesson表数据存在 study_record_obj = self.session.query(Study_record).filter_by(class_m2m_lesson_id=class_m2m_lesson_obj.id).first()
if not study_record_obj: # 上课记录为创建
for student_obj in class_obj.students:
status = input("输入学生 %s 的上课状态(yes/no):"%student_obj.stu_name)
study_record_new = Study_record(class_m2m_lesson_id=class_m2m_lesson_obj.id,
stu_id=student_obj.stu_id,
status=status)
self.session.add(study_record_new)
self.session.commit()
else:
print("\33[31;1m系统错误:当前上课记录已经创建\33[0m")
else:
print("\33[31;1m系统错误:当前班级的lesson课节未创建\33[0m")
else:
print("\33[31;1m系统错误:lesson未创建\33[0m")
else:
print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m") def modify_scores(self):
'''修改成绩'''
class_name = input("\033[34;0m请输入学习记录的班级名:\033[0m")
class_obj = self.session.query(Class).filter_by(class_name=class_name).first() if class_obj and class_obj.teachers[0] == self.teacher_obj: # 输入的班级名存在且在属于当前老师管理
lesson_name = input("\033[34;0m请输入学习记录的课节名(lesson):\033[0m")
lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first() if lesson_obj: # 输入的lesson名字存在
class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(
Class_m2m_Lesson.class_id == class_obj.class_id). \
filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first() if class_m2m_lesson_obj: # 班级对应的课lesson表数据存在
while True:
study_record_objs = self.session.query(Study_record).filter(
Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).all()
for obj in study_record_objs:
print(obj) student_name = input("\033[34;0m输入要修改成绩的学生名:[Q 退出]\33[0m")
if student_name == "q" or student_name == "Q":break
student_obj = self.session.query(Student).filter_by(stu_name=student_name).first()
if student_obj:
study_record_obj = self.session.query(Study_record).filter(
Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).filter(
Study_record.stu_id == student_obj.stu_id).first() if study_record_obj: # 上课记录存在
score = input("\033[34;0m输入修改后的成绩\33[0m")
study_record_obj.score= score
self.session.commit() else:
print("\33[31;1m系统错误:当前上课记录已经创建\33[0m")
else:
print("\33[31;1m系统错误:当前班级的lesson课节未创建\33[0m")
else:
print("\33[31;1m系统错误:lesson未创建\33[0m")
else:
print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m") def exit(self):
exit()

教师视图

不足

  1. readme文件写的不够详细,测试环境没有写详细
  2. 入口文件路径不对
  3. 代码存在现实逻辑缺陷(因为完成作业需求,暂时不计较)

完整代码

https://github.com/lixiaoliuer1229/work_demo/tree/master/day12

学院管理系统(mysql版)的更多相关文章

  1. 基于JSP的学生考勤管理系统(MySQL版)

    介绍:基于JSP的学生考勤管理系统(MySQL版)1.包含源程序,数据库脚本.代码和数据库脚本都有详细注释.2.课题设计仅供参考学习使用,可以在此基础上进行扩展完善.开发环境:Eclipse ,MyS ...

  2. 美萍超市销售管理系统标准版access数据库密码mp611

    美萍超市销售管理系统标准版access数据库密码mp611 作者:admin  来源:本站  发表时间:2015-10-14 19:01:43  点击:199 美萍超市销售管理系统标准版access后 ...

  3. 常用的PHP数据库操作方法(MYSQL版)

    常用的PHP数据库操作方法(MYSQL版) 作者: 字体:[增加 减小] 类型:转载 时间:2011-06-08   最近一直在折腾自己的网站首页,写的大部分PHP脚本都要用到和MYSQL数据库相关的 ...

  4. 全国省市级联数据sql语句 mysql版

    全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...

  5. SQL优化 MySQL版 - B树索引详讲

    SQL优化 MySQL版  - -B树索引详讲 作者:Stanley 罗昊 [转载请注明出处和署名,谢谢!] 为什么要进行SQL优化呢?很显然,当我们去写sql语句时: 1会发现性能低 2.执行时间太 ...

  6. SQL优化 MySQL版 -分析explain SQL执行计划与笛卡尔积

    SQL优化 MySQL版 -分析explain SQL执行计划 作者 Stanley 罗昊 [转载请注明出处和署名,谢谢!] 首先我们先创建一个数据库,数据库中分别写三张表来存储数据; course: ...

  7. SQL优化 MySQL版 - 索引分类、创建方式、删除索引、查看索引、SQL性能问题

    SQL优化 MySQL版  - 索引分类.创建方式.删除索引.查看索引.SQL性能问题 作者 Stanley 罗昊 [转载请注明出处和署名,谢谢!] 索引分类 单值索引 单的意思就是单列的值,比如说有 ...

  8. 蓝点通用管理系统V13版发布了!

    蓝点通用管理系统13版已发布! 重磅新功能:系统的通知和提醒功能,增加微信方式,微信通知.微信查询数据.微信拍照上传....... 蓝点的客户管理系统.进销存管理系统.产品管理系统.工作流管理系统.投 ...

  9. MYSQL版查询分页存储过程

    /*--名称:MYSQL版查询分页存储过程 --输入参数:@fields -- 要查询的字段用逗号隔开--输入参数:@tables -- 要查询的表--输入参数:@where -- 查询条件--输入参 ...

  10. abp zero mysql版正式发布

    AbpZero-MySql aspnet-zero-1.12.0的mysql版本来啦.跟mssql版一样的功能,一样的代码. 获取源码

随机推荐

  1. Centos7.3 为php7 安装swoole 扩展

    今天心血来潮想在服务器上安装一下swoole扩展  下面列一下教程: xshell进入你的服务器  然后目录自选吧  反正我放在根目录了 下面是扩展链接: wget https://github.co ...

  2. (三)springmvc之注解的基本使用

    一.@Controller @Controller 标记一个类是Controller 二.RequestMapping  地址映射 2.1 Value的操作. 注解在类上面    (父)       ...

  3. 【原创】大叔经验分享(84)spark sql中设置hive.exec.max.dynamic.partitions无效

    spark 2.4 spark sql中执行 set hive.exec.max.dynamic.partitions=10000; 后再执行sql依然会报错: org.apache.hadoop.h ...

  4. 最简单的理解 建立TCP连接 三次握手协议

     最简单的理解一:建立TCP连接:三次握手协议    客户端:我要对你讲话,你能听到吗:服务端:我能听到:而且我也要对你讲话,你能听到吗:客户端:我也能听到.…….互相开始通话…….. 二:关闭TCP ...

  5. 异常信息:javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed

    上周五遇到一个问题,工程本地编译运行正常,打包本地tomcat运行也正常.部署到测试环境报错: 2017-05-05 09:38:11.645 ERROR [HttpPoolClientsUtil.j ...

  6. nginx 反向代理的配置

    nginx中的每个server就是一个反向代理配置,可以有多个server(nginx只能处理静态资源) nginx中 server的配置 server { listen 80; server_nam ...

  7. git基本命令总结

    介绍 上一篇博客介绍了git的基本使用方式,建议可以去阅读一下廖雪峰关于git的文章写的十分详细,并且通俗易懂,这篇博客主要是总结上一篇博客中用到的git命令,方便使用查询. git常用命令小结 gi ...

  8. Java基础加强-代理

    /*代理*//*代理的概念与作用*/ 代理过程架构 客户端Client原来直接调用的是Target目标类 使用代理后,现在让客户端不要调用Target,调用代理类Proxy,代理类Proxy和目标类T ...

  9. zabbix-通过自动注册自动添加主机

    自动注册和自动发现可以实现一样的效果,就是自动添加符合条件的主机到监控,那跟自动发现有什么区别? 其实自动发现是由弊端的,上文也说到了,zabbix server是主动去扫描网段,寻找agent的,试 ...

  10. linux-2.6.38 IIC驱动框架分析

    在linux-2.6内核中,IIC的驱动程序可以大概分为三部分: (1)IIC核心代码:/drivers/i2c/i2c-core.c IIC核心提供了IIC总线驱动和设备驱动的注册.注销方法和IIC ...