数据库系统原理之数据库应用设计与开发实例

数据库应用设计与开发实例

第一节 需求描述与分析

在此,结合某高校个性化课程在线选课的实际需求,给出一个简化的需求分析

一、功能性需求

1 管理员后台模块

  • 学生信息管理
  • 教师信息管理
  • 课程信息管理
  • 班级信息管理

2 学生使用模块

  • 查询课程
  • 浏览所选课程
  • 查询成绩

3 教师使用模块

  • 我的课程
  • 登分

二、非功能性需求

在线选课系统

浏览器/服务器(B/S) 结构

  • 选课系统质量需求:
    • 可靠性
    • 正确性
    • 兼容性
    • 健壮性

第二节 系统设计

自顶向下 功能模块结构图

一、功能模块设计

  • 登录验证模块
  • 管理员后台模块
    • 学生信息管理模块
    • 教师信息管理模块
    • 课程信息管理模块
    • 院系信息管理模块
  • 学生使用模块
    • 查询课程模块
    • 浏览已选课程模块
    • 选课及退选模块
    • 成绩查询模块
  • 教师使用模块
    • 我的课程模块
    • 登分模块

二、数据库设计

1 确定实体

  • 学生实体用于描述学生的基本信息,包括学号、姓名、性别、密码等信息。
  • 教师实体用于描述教师的基本信息,包括教师工号、姓名、性别、年龄、职称、密码登信息。
  • 课程实体用于描述课程的基本信息,包括课程号、课程名、学分、时间、地点、类别、开课学院、限选人数等信息。
  • 院系实体用于描述院系的基本信息,包括院系名称、办公地点、教师人数等信息。
  • 系统管理员实体用于描述系统管理员的基本信息,包括姓名、ID号、密码登信息。

注意:在数据库设计时,实体的描述信息可根据实际需求进行增加或删减,如果实体的属性较多,在构建 E-R 模型时不一定需要把所有的属性都标识在E-R 模型上,可以另外用文字说明,这样也使得 E-R 模型简明清晰,便于分析。

2 局部信息结构

  • 学生-课程 “选修” 多对多(M:N)
  • 教师-课程 “授课” 一对多(1:N)
  • 教师-院系 “属于” 一对多(1:N)
  • 学生-院系 “属于” 一对多(1:N)
  • 系统管理员-学生 “管理” 多对多 (M:N)
  • 系统管理员-教师 “管理” 多对多 (M:N)
  • 系统管理员-课程 “管理” 多对多 (M:N)
  • 系统管理员-院系 “管理” 多对多 (M:N)

3 全局信息结构

  • 首先将学生-课程E-R图、教师-课程E-R图,教师-院系E-R图、学生-院系E-R图合并成为一个较大的局部信息结构。
    • 学生-教师-课程-院系 E-R 图
  • 将 系统管理员-学生、系统管理员-教师、系统管理员-课程、系统管理员-院系的E-R图合并成为一个较大的局部信息结构。
    • 系统管理员-学生-教师-课程-院系 E-R 图
  • 最后,将 学生-教师-课程-院系 E-R 图和系统管理员-学生-教师-课程-院系 E-R 图合并成为一个本系统的全局 E-R 图。

4 逻辑结构与规范化设计

转换为关系模式,主码用下划线标识

  • 学生(学号、姓名、性别、登录密码、院系编号)
  • 院系(院系编号、系名、学生人数、教师人数、办公地点)
  • 教师(职工号、姓名、性别、年龄、职称、登录密码、院系编号)
  • 课程(课程号、课程名称、课程类别、学分、上课时间、上课地点、开课学院、限选人数、职工号)
  • 系统管理员(ID号、姓名、登录密码)
  • 选修(学号、课程号、成绩)
  • 管理学生(管理员 ID 号、学号、操作时间)
  • 管理院系(管理员 ID 号、院系编号、操作时间)
  • 管理教师(管理员 ID 号、职工号、操作时间)
  • 管理课程( 管理员 ID 号、课程号、操作时间)

E-R 图 关系模式 第三范式

院系

院系编码(院系编号、系名)

院系(院系编号、学生人数、教师人数、办公地点)

课程

课程编码(课程号、课程名称)

课程(课程号、课程类别、学分、上课时间、上课地点、开课学院、限选人数、职工号)

第三节 系统实现

1 数据库的实现

  • 创建数据库
mysql> create database db_xuanke;
Query OK, 1 row affected (0.00 sec)

mysql>

  • 创建表
    • 学生信息表 student
    • 院系编码表 deptcode
    • 院系表 department
    • 教师表 teacher
    • 课程编码表 coursecode
    • 课程表 course
    • 系统管理员表 administrator
    • 选修表 electing
    • 管理学生表 adminstu
    • 管理院系表 admindept
    • 管理教师表 adminteacher
    • 管理课程表 admincourse

2 系统功能的实现

  • 实现数据库行为
    • 安全控制
    • 管理学生
    • 数据库保护
    • 事务与并发控制
    • 数据查询与统计报表
  • 实现应用软件的业务逻辑

第四节 系统测试与维护

1 登录验证功能测试

2 管理员后台主要功能测试

  • 学生信息管理功能
  • 课程信息管理功能

3 学生使用模块功能测试

4 教师使用模块功能测试

原文链接:https://www.cnblogs.com/QiaoPengjun/p/17288085.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:数据库系统原理之数据库应用设计与开发实例 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • 解决大于5.7版本mysql的分组报错Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated

    这个报错是由于MySQL 5.7版本以后对于分组查询的规则进行了更改导致的。现在要求分组查询中选择的列必须要么出现在GROUP BY子句中,要么是聚合函数,否则会报错。如果数据表中存在要查询的字段中有出现在GROUP BY子句中的列之外的字段时,就会出现“Expression #1 of SELECT list is not in GROUP BY clau…

    MySQL 2023年5月18日
    00
  • mysql升级后报Table ‘mysql.servers’ doesn’t exist

    解决Table ‘mysql.servers’ doesn’t exist 今天遇到一事,就是我在升级mysql数据库后进入数据建立一远程用户,结果报错了。 mysql> flush privileges; ERROR 1146 (42S02): Table ‘mysql.servers’ doesn’t exist   这是由于升级完数据库后丢失原有…

    MySQL 2023年4月12日
    00
  • 白嫖一个月的ES,完成了与MySQL的联动

    前言 《腾讯云 x Elasticsearch三周年》活动来了。文章写之前的思路是:在腾讯云服务器使用docker搭建ES。但是理想很丰满,显示很骨感,在操作过程中一波三折,最后还是含着泪美滋滋地,白嫖了一个月的腾讯云ES服务。 最后就是利用腾讯云的Elasticsearch和Kibana,和我在腾讯云服务器上搭建MySQL进行了一波联动,完成了数据库内部指…

    2023年4月8日
    00
  • MySQL主从复制原理剖析与应用实践

    MySQL Replication(主从复制)是指数据变化可以从一个MySQL Server被复制到另一个或多个MySQL Server上,通过复制的功能,可以在单点服务的基础上扩充数据库的高可用性、可扩展性等。 vivo 互联网服务器团队- Shang Yongxing MySQL Replication(主从复制)是指数据变化可以从一个MySQL Ser…

    MySQL 2023年4月13日
    00
  • MySQL 压缩的使用场景和解决方案

    MySQL 压缩的使用场景和解决方案 压缩的使用场景 MySQL 压缩的使用场景一般是数据量过大,导致对于磁盘空间的占用过多,对数据库的备份和恢复也变得困难。此时可以选择使用 MySQL 压缩的功能来缩小数据的空间占用,提高数据库的备份和恢复效率。 解决方案 MySQL 内置了多种压缩的方式,可以通过以下方法进行压缩: 1. 使用 MyISAM 表 MyIS…

    MySQL 2023年5月19日
    00
  • MySQL如何查看和修改默认存储引擎

    MySQL默认存储引擎是指在创建表时未指定存储引擎时所使用的默认存储引擎。MySQL提供了多种存储引擎,如InnoDB、MyISAM、Memory等,每种存储引擎都有其特点和适用场景。 因此,查看和修改默认存储引擎可以在不同的场景下优化性能和减少空间占用。 MySQL查看默认存储引擎 通过查询系统变量来查看当前的默认存储引擎 在MySQL客户端中输入以下命令…

    MySQL 2023年3月9日
    00
  • MySQL 、SQL MS Access、和 SQL Server 数据类型

    MySQL 数据类型 在 MySQL 中,有三种主要的类型:Text(文本)、Number(数字)和 Date/Time(日期/时间)类型。 Text 类型: 数据类型 描述 CHAR(size) 保存固定长度的字符串(可包含字母、数字以及特殊字符)。在括号中指定字符串的长度。最多 255 个字符。 VARCHAR(size) 保存可变长度的字符串(可包含字…

    MySQL 2023年4月13日
    00
  • Mysql报错[Warning] TIMESTAMP with implicit DEFAULT value is deprecated和Buffered warning: Changed limits

    报错2019-04-24 12:06:46 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use –explicit_defaults_for_timestamp server option (see documentation for more detail…

    MySQL 2023年4月16日
    00
合作推广
合作推广
分享本页
返回顶部