EasyUI+JavaWeb奖助学金管理系统[3]-数据库结构设计

简介: 本文目录1. 本章任务2. 项目表project3. 机构表depart4. 用户表user5. 菜单表 role6. 角色菜单表roleMenu7. 问题反馈表 question8. 审核流程表flow9. 总结

1. 本章任务

根据需求分析的结果,设计下数据库结构。数据库结构非常重要,一个好的库结构能让开发事半功倍,一个垃圾的结构会让开发人员癫狂…


数据库结构就是软件大厦的地基。


2. 项目表project

学生要申报各种奖助学金项目,所以需要有项目表存储项目信息。


包括:唯一编号、类型(奖学金/助学金)、名称、描述。


注意类型字段只有两种,所以直接写死award/help,或者用1/2代表奖学金、助学金。


此处由于性能和存储空间问题不大,所以选用更好理解的award/help。


3. 机构表depart

需要存储学校、学院、班级及他们直接的归属关系,所以设计机构表。


包括:唯一编号、机构名称、机构类型(学校/学院/班级)、上级机构编号。


注意:机构类型只有三种,所以写死school/college/class。


上级机构编号,存储是当前机构上级机构的id,例如计算机学院编号是11,则计算机学院1班的上级机构编号就是11。


4. 用户表user

用户表存储各类用户信息,包括:


唯一编号、用户名称、登录名、登录密码、用户角色、用户所属机构id。


注意用户角色为学校管理员、学院管理员、班主任、学生,数据库字段存储为schoolmaster/collegemaster/classmaster/student。


用户所属机构id存储的是当前用户所属的机构的唯一编号。通过该字段就能知道各个机构有哪些用户。


5. 菜单表 role

为了实现不同用户可以拥有不同的菜单,首先将菜单信息存入菜单表。


包括:唯一编号、菜单名称、菜单访问路径。


其中菜单访问路径统一规划为请求的Servlet的路径,不允许直接跳转jsp页面,这样便于进行管理。


6. 角色菜单表roleMenu

保存用户角色和菜单的对应关系,多对多的关系。


包括:唯一编号、角色号、菜单号。


通过roleMenu就能知道当前用户角色可以访问哪些菜单。


7. 问题反馈表 question

记录反馈的问题及答复信息,包括:


唯一编号、提交问题的用户编号、用户名称、机构编号、机构名称、问题内容、答复内容。


这个比较简单,就是一个记录的功能。


8. 审核流程表flow

记录学生提交的申请单及审批情况。


包括:唯一编号、学生编号、学生姓名、申请项目编号、项目名称、申请内容(文字描述);


班主任id、班主任审核意见(同意、驳回)、学院管理员id、学院管理员审核意见、学校管理员id、学校管理员审核意见、当前审核节点。


注意:审核意见只有同意和驳回,分别用yes/no表示。


当前审核节点用class/college/shcool/success/return,分别表示待班主任审核、待学院审核、待学校审核、审核通过、驳回。


9. 总结

本系统的数据库结构并不复杂,但是麻雀虽小五脏俱全,还是非常有代表性的。


非常完美吭。

相关文章
|
4月前
|
关系型数据库 OLAP 分布式数据库
核心系统转型问题之Gartner分析师对阿里云数据库的评价是啥样的
核心系统转型问题之Gartner分析师对阿里云数据库的评价是啥样的
|
4月前
|
Cloud Native 数据管理 数据挖掘
核心系统转型问题之阿里云数据库用户需求的通用性和差异性如何平衡
核心系统转型问题之阿里云数据库用户需求的通用性和差异性如何平衡
|
1月前
|
数据库连接 Go 数据库
Go语言中的错误注入与防御编程。错误注入通过模拟网络故障、数据库错误等,测试系统稳定性
本文探讨了Go语言中的错误注入与防御编程。错误注入通过模拟网络故障、数据库错误等,测试系统稳定性;防御编程则强调在编码时考虑各种错误情况,确保程序健壮性。文章详细介绍了这两种技术在Go语言中的实现方法及其重要性,旨在提升软件质量和可靠性。
38 1
|
1月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
124 3
|
1月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
43 1
|
2月前
|
SQL 存储 关系型数据库
数据储存数据库管理系统(DBMS)
【10月更文挑战第11天】
161 3
|
2月前
|
存储 关系型数据库 MySQL
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
45 2
|
3月前
|
JavaScript Java 关系型数据库
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
本文介绍了一个基于Spring Boot和Vue.js实现的在线考试系统。随着在线教育的发展,在线考试系统的重要性日益凸显。该系统不仅能提高教学效率,减轻教师负担,还为学生提供了灵活便捷的考试方式。技术栈包括Spring Boot、Vue.js、Element-UI等,支持多种角色登录,具备考试管理、题库管理、成绩查询等功能。系统采用前后端分离架构,具备高性能和扩展性,未来可进一步优化并引入AI技术提升智能化水平。
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
|
3月前
|
Java 关系型数据库 MySQL
毕设项目&课程设计&毕设项目:springboot+jsp实现的房屋租租赁系统(含教程&源码&数据库数据)
本文介绍了一款基于Spring Boot和JSP技术的房屋租赁系统,旨在通过自动化和信息化手段提升房屋管理效率,优化租户体验。系统采用JDK 1.8、Maven 3.6、MySQL 8.0、JSP、Layui和Spring Boot 2.0等技术栈,实现了高效的房源管理和便捷的租户服务。通过该系统,房东可以轻松管理房源,租户可以快速找到合适的住所,双方都能享受数字化带来的便利。未来,系统将持续优化升级,提供更多完善的服务。
毕设项目&课程设计&毕设项目:springboot+jsp实现的房屋租租赁系统(含教程&源码&数据库数据)
|
2月前
|
安全 NoSQL 关系型数据库
阿里云数据库:构建高性能与安全的数据管理系统
在企业数字化转型过程中,数据库是支撑企业业务运转的核心。随着数据量的急剧增长和数据处理需求的不断增加,企业需要一个既能提供高性能又能保障数据安全的数据库解决方案。阿里云数据库产品为企业提供了一站式的数据管理服务,涵盖关系型、非关系型、内存数据库等多种类型,帮助企业构建高效的数据基础设施。
141 2