校园选课助手【1】-项目整体架构从此开始

  1. 项目背景

    随着高校招生规模的不断扩大,学生选课需求日益增长。为提高选课效率,降低学生选课压力,本项目旨在开发一款校园选课助手软件。

  2. 项目目标:开发一款具有以下特点的校园选课助手软件:

    易用性:界面简洁,操作简便,便于学生快速上手。

    功能性:满足学生选课、退课、查询课程信息等需求。

    高效性:提高选课速度,减少学生选课时间。

    可靠性:确保软件稳定运行,降低故障率。

  3. 项目范围

    本项目涉及以下方面:

    软件开发:包括需求分析、设计、编码、测试和部署等环节。

    技术支持:为软件提供持续的技术维护和升级。

  4. 需求分析

    4.1 功能需求

    用户注册与登录:用户需注册账号并登录,方可使用选课功能。

    课程查询:用户可按课程名称、课程代码、教师姓名等条件查询课程信息。

    选课:用户可根据个人需求选择课程,并加入选课列表。

    退课:用户可从选课列表中移除已选课程。

    个人中心:用户可查看已选课程、课程表、成绩等信息。

    4.2非功能需求

    界面友好:界面设计简洁、美观,操作简便。

    响应速度:系统响应速度快,满足大量用户同时访问。

    数据安全:确保用户数据和课程数据的安全。

  5. 系统设计

    5.1 架构设计

    采用前后端分离的架构,前端负责展示界面和交互,后端负责数据处理和业务逻辑。

    5.2 技术选型

    前端:HTML5、CSS3、JavaScript、Ajax

    后端:Spring MVC、Mybatis、Redis、RabbitMQ、MySQL、Elasticsearch

    数据库:MySQL、Elasticsearch

    5.3 界面设计

    根据需求分析,设计以下界面:

    登录界面

    注册界面

    课程查询界面

    选课界面

    退课界面

    个人中心界面

    5.4 数据库设计

MySQL设计以下数据库表:

用户表:包含用户ID、用户名、密码、手机号等信息。

bash 复制代码
CREATE TABLE `t_user` (
  `id` bigint(20) NOT NULL COMMENT '用户ID,手机号码',
  `nickname` varchar(255) NOT NULL,
  `password` varchar(32) DEFAULT NULL COMMENT 'MD5(MD5(pass明文+固定salt)+salt)',
  `salt` varchar(10) DEFAULT NULL,
  `head` varchar(128) DEFAULT NULL COMMENT '头像',
  `register_date` datetime DEFAULT NULL COMMENT '注册时间',
  `last_login_date` datetime DEFAULT NULL COMMENT '最后一次登录时间',
  `login_count` int(11) DEFAULT '0' COMMENT '登录次数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

课程表:包含课程名称、课程代码、教师姓名、学分、课时、余量等信息。

bash 复制代码
CREATE TABLE `t_course` (
  `course_name` varchar(16) DEFAULT NULL COMMENT '课程名称',
  `course_id` varchar(20) NOT NULL COMMENT '课程代码',
  `course_teacher` varchar(20) NOT NULL COMMENT '授课老师',
  `course_detail` longtext COMMENT '课程详情',
  `course_attribute` int(11) DEFAULT '0' COMMENT '课程属性,0必修',
  `course_price` decimal(10,2) DEFAULT '0.00' COMMENT '学分',
  `course_stock` int(11) DEFAULT '0' COMMENT '库存,-1表示没有限制',
  PRIMARY KEY (`course_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4;

选课表:包含选课ID、用户ID、课程ID、选课状态等信息。

bash 复制代码
CREATE TABLE `t_order` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '选课ID',
  `user_id` bigint(20) DEFAULT NULL COMMENT '用户ID',
  `goods_id` bigint(20) DEFAULT NULL COMMENT '课程ID',
  `order_channel` tinyint(4) DEFAULT '0' COMMENT '1 pc,2 android, 3 ios',
  `status` tinyint(4) DEFAULT '0' COMMENT '订单状态,0新建未确认,1已确认',
  `create_date` datetime DEFAULT NULL COMMENT '订单创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=64912 DEFAULT CHARSET=utf8mb4;

Elasticsearch设计索引表:

bash 复制代码
PUT /classes
{
  "mappings": {
    "properties": {
      "id": {
        "type": "keyword"
      },
      "name":{
        "type": "text",
        "analyzer": "ik_max_word"
      },
      "teacher_name":{
        "type": "keyword"
      },
      "score":{
        "type": "integer",
      },
      "time":{
        "type": "integer"
      }
    }
  }
}
相关推荐
binishuaio4 分钟前
Java 第11天 (git版本控制器基础用法)
java·开发语言·git
zz.YE6 分钟前
【Java SE】StringBuffer
java·开发语言
老友@6 分钟前
aspose如何获取PPT放映页“切换”的“持续时间”值
java·powerpoint·aspose
wrx繁星点点21 分钟前
状态模式(State Pattern)详解
java·开发语言·ui·设计模式·状态模式
Upaaui24 分钟前
Aop+自定义注解实现数据字典映射
java
zzzgd81624 分钟前
easyexcel实现自定义的策略类, 最后追加错误提示列, 自适应列宽,自动合并重复单元格, 美化表头
java·excel·表格·easyexcel·导入导出
友善的鸡蛋25 分钟前
解决:使用EasyExcel导入Excel模板时出现数据导入不进去的问题
java·easyexcel·excel导入
星沁城26 分钟前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
NoneCoder38 分钟前
Java企业级开发系列(1)
java·开发语言·spring·团队开发·开发
一只爱好编程的程序猿40 分钟前
Java后台生成指定路径下创建指定名称的文件
java·python·数据下载