★观前提示:本篇内容为mysql数据库实验,代码内容经测试过,可能一小部分有所疏漏,也有会不符合每个人实验的要求的地方,因此以下内容建议仅做思路参考,。

一、实验目的

1、理解并能运用数据库设计的常见步骤来设计满足给定需求的概念模型(ER模型)和关系数据模型;
2、能结合有关的指南对模型进行优化处理。
3、能够在某主流DBMS上创建数据库模式、所建数据库模式满足用户的基本业务需求。

二、实验要求

从选题出发,按照数据库设计步骤,完成该选题语义所对应的数据库的概念结构设计、逻辑结构设计及数据库的物理实现。

★温馨提示:以下内容均已经过测试,不过难免会有疏漏,但是代码实现大多数思路及实现经测验都是正确的。

三、实现内容及步骤

①从简单的选题语义出发,按照数据库设计步骤,分别完成如下内容:概念设计(ER模型),给出满足需求的最终全局ER图,要求模型尽量精简,消除不必要的冗余,并给出理由或说明。

mysql数据库课设案例 mysql数据库课程设计课题_数据库

②逻辑设计(关系模型),把ER模型转换成适当的关系模式,并进行适当地规范化(可选),设计相关完整性约束,指出主键跟外键。

学生(学号、姓名、性别、专业、班级、寝室号) 主键:学号 外键:寝室号

寝室(寝室号、寝室电话、员工号) 主键:寝室号 外键:员工号

管理员(员工号、姓名、联系电话) 主键:员工号

完整性约束:

一、学生表:student

mysql数据库课设案例 mysql数据库课程设计课题_数据库_02

二、寝室表:dormitory

mysql数据库课设案例 mysql数据库课程设计课题_外键_03

三、管理员表:admin

mysql数据库课设案例 mysql数据库课程设计课题_database_04

③物理设计,在某一主流DBMS中创建数据库,根据业务需求规划适当索引(包括聚簇索引和非聚簇索引),并设计必要的用户视图(即外模式),完成相关查询或更新要求。

第一步:先创建一个数据库(实验六_简单数据库设计)

mysql数据库课设案例 mysql数据库课程设计课题_database_05

第二步:建立学生表 (student)、寝室表 (dormitory) 跟 管理员表 (admin)

1️⃣创建学生表(student)

mysql数据库课设案例 mysql数据库课程设计课题_数据库_06

mysql数据库课设案例 mysql数据库课程设计课题_外键_07

2️⃣创建寝室表(dormitory)

mysql数据库课设案例 mysql数据库课程设计课题_mysql数据库课设案例_08

mysql数据库课设案例 mysql数据库课程设计课题_外键_09

3️⃣创建管理表 (admin)

mysql数据库课设案例 mysql数据库课程设计课题_数据库_10

mysql数据库课设案例 mysql数据库课程设计课题_mysql数据库课设案例_11

第三步:添加外键约束

1️⃣添加dno的外键约束

mysql数据库课设案例 mysql数据库课程设计课题_mysql_12

mysql数据库课设案例 mysql数据库课程设计课题_外键_13

2️⃣添加ano的外键约束

mysql数据库课设案例 mysql数据库课程设计课题_数据库_14

mysql数据库课设案例 mysql数据库课程设计课题_数据库_15

第四步:添加视图(v_student)

mysql数据库课设案例 mysql数据库课程设计课题_mysql数据库课设案例_16

mysql数据库课设案例 mysql数据库课程设计课题_外键_17

第五步:读入数据(admin、dormitory、student 表)

1️⃣admin 表

mysql数据库课设案例 mysql数据库课程设计课题_数据库_18

2️⃣dormitory 表

mysql数据库课设案例 mysql数据库课程设计课题_mysql_19

3️⃣student 表

mysql数据库课设案例 mysql数据库课程设计课题_数据库_20

第六步:实验测试外键ano跟dno

1️⃣测试外键约束ano

mysql数据库课设案例 mysql数据库课程设计课题_数据库_21

因为有外键的约束,故无法在dormitory表中加入的数据中的ano跟admin表中的数据ano不一样。

2️⃣测试外键约束dno

mysql数据库课设案例 mysql数据库课程设计课题_database_22

因为有外键的约束,故无法在student表中加入的数据中的dno跟dormitory表中的数据dno不一样。

四、实验总结

1、通过本次实验,对存储过程和触发器有了更深的认识;

2、能够理解不同类型触发器的作用和执行原理, 验证了触发器的有效性;

3、熟练掌握了数据库存储过程定义、存储过程运行,存储过程更名,存储过程删除,存储过程的参数传递。

2022.6.14记录:Code_流苏
如有任何疑问,评论回复,看到即回,欢迎大家多多交流学习!
★以上实验内容仅供参考。