★观前提示:本篇内容为mysql数据库实验,代码内容经测试过,可能一小部分有所疏漏,也有会不符合每个人实验的要求的地方,因此以下内容建议仅做思路参考,。
一、实验目的
1、理解并能运用数据库设计的常见步骤来设计满足给定需求的概念模型(ER模型)和关系数据模型;
2、能结合有关的指南对模型进行优化处理。
3、能够在某主流DBMS上创建数据库模式、所建数据库模式满足用户的基本业务需求。
二、实验要求
从选题出发,按照数据库设计步骤,完成该选题语义所对应的数据库的概念结构设计、逻辑结构设计及数据库的物理实现。
★温馨提示:以下内容均已经过测试,不过难免会有疏漏,但是代码实现大多数思路及实现经测验都是正确的。
三、实现内容及步骤
①从简单的选题语义出发,按照数据库设计步骤,分别完成如下内容:概念设计(ER模型),给出满足需求的最终全局ER图,要求模型尽量精简,消除不必要的冗余,并给出理由或说明。
②逻辑设计(关系模型),把ER模型转换成适当的关系模式,并进行适当地规范化(可选),设计相关完整性约束,指出主键跟外键。
学生(学号、姓名、性别、专业、班级、寝室号) 主键:学号 外键:寝室号
寝室(寝室号、寝室电话、员工号) 主键:寝室号 外键:员工号
管理员(员工号、姓名、联系电话) 主键:员工号
完整性约束:
一、学生表:student
二、寝室表:dormitory
三、管理员表:admin
③物理设计,在某一主流DBMS中创建数据库,根据业务需求规划适当索引(包括聚簇索引和非聚簇索引),并设计必要的用户视图(即外模式),完成相关查询或更新要求。
第一步:先创建一个数据库(实验六_简单数据库设计)
第二步:建立学生表 (student)、寝室表 (dormitory) 跟 管理员表 (admin)
1️⃣创建学生表(student)
2️⃣创建寝室表(dormitory)
3️⃣创建管理表 (admin)
第三步:添加外键约束
1️⃣添加dno的外键约束
2️⃣添加ano的外键约束
第四步:添加视图(v_student)
第五步:读入数据(admin、dormitory、student 表)
1️⃣admin 表
2️⃣dormitory 表
3️⃣student 表
第六步:实验测试外键ano跟dno
1️⃣测试外键约束ano
因为有外键的约束,故无法在dormitory表中加入的数据中的ano跟admin表中的数据ano不一样。
2️⃣测试外键约束dno
因为有外键的约束,故无法在student表中加入的数据中的dno跟dormitory表中的数据dno不一样。
四、实验总结
1、通过本次实验,对存储过程和触发器有了更深的认识;
2、能够理解不同类型触发器的作用和执行原理, 验证了触发器的有效性;
3、熟练掌握了数据库存储过程定义、存储过程运行,存储过程更名,存储过程删除,存储过程的参数传递。
2022.6.14记录:Code_流苏
如有任何疑问,评论回复,看到即回,欢迎大家多多交流学习!
★以上实验内容仅供参考。