数据库实验——简单数据库应用系统设计与实现

数据库实验——简单数据库应用系统设计与实现

某学生宿舍管理系统,涉及的部分信息如下:
学生:学号,姓名,性别,专业,班级。
寝室:寝室号,房间电话。
管理员:员工号,姓名,联系电话。
其中:每个寝室可同时住宿多名学生,每名学生只分配一个寝室;每个寝室指定其中一名学生担当寝室长;每个管理员同时管理多个寝室,但每个寝室只有一名管理员。
每组同学从以上选题中任选一个进行相应的设计与实现。要求如下:
(1)从简单的选题语义出发,按照数据库设计步骤,分别完成如下内容:概念设计(ER模型),给出满足需求的最终全局ER图,要求模型尽量精简,消除不必要的冗余,并给出理由或说明。
(2)逻辑设计(关系模型),把ER模型转换成适当的关系模式,并进行适当地规范化(可选),设计相关完整性约束。
(3)物理设计,在某一主流DBMS中创建数据库,根据业务需求规划适当索引(包括聚簇索引和非聚簇索引),并设计必要的用户视图(即外模式),完成相关查询或更新要求。
四、实验要求
1、完成上述任务;
2、完成实验报告(包括上述任务中的E-R图、转换后的关系模型及优化过程、创建数据库的SQL语句)


E-R图


关系模式

学生(学号,姓名,性别,专业,班级,寝室号)

寝室(寝室号,房间电话,员工号)   管理员(员工号,姓名,联系电话)


物理实现

使用mysql8.0

第一步

创建数据库,并选择

CREATE DATABASE shiyan;
use shiyan;

第二步

创建学生表,宿舍表,管理员表

//学生表
CREATE TABLE student(
 sno int(5) PRIMARY KEY ,
 name varchar(6) NOT NULL,
 sex ENUM('男','女') DEFAULT '女',
 dept varchar(10),
 class varchar(10),
 dno int(5));
 
//宿舍表
CREATE TABLE dormitory(
 dno int(5) PRIMARY KEY ,
 phone varchar(11) NOT NULL,
 mno int(5)
);

//管理员表
CREATE TABLE manager(
 mno int(5) PRIMARY KEY ,
 name varchar(10) NOT NULL,
 mphone varchar(11) NOT NULL
);

第三步

添加约束和索引

给student表的dno添加外键约束

给dormitory表的mno添加外键约束

若这是一个实际应用的系统,那么学生查询无异于频繁的,所以为学生的姓名添加普通索引

//添加普通索引
alter table add index s_name('name');
//添加dno的外键约束
ALTER TABLE student ADD CONSTRAINT FK_ST_DO foreign key(dno) REFERENCES dormitory(dno);
//添加mno的外键约束
ALTER TABLE dormitory ADD CONSTRAINT FK_DO_MA foreign key(mno) REFERENCES manager(mno)

第四步

创建视图

create view v_student as select sno,name,sex,dept,class,dno from student;

第五步

插入数据

//manager表
INSERT INTO manager VALUES(12345,18989341833)
//dormitory表
INSERT INTO dormitory VALUES(12345,18989341832,12346)
//student表
INSERT INTO `student` (`sno`, `name`, `sex`, `dept`, `class`, `dno`) VALUES ('12345', '李铭炜', '男', '计算机科学与技术', '计科一班', '12345');

以下是外键生效的效果

 

 

 

 

 

 

 

 

 

 

 

 

  • 12
    点赞
  • 149
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
数据库应用系统设计实现 实验类型:设计型 实验地点:2楼312 实验时间:12月14日、21日周五1-3/5-7节 实验内容: 系统概述: 某银行需要开发ATM存取款机系统实现如下功能: 1)开户(到银行填写开户申请单,卡号自动生成) 2)取款 3)存款 4)查询余额 题目要求: 一、建库、建表、建约束 1、使用SQL创建表 客户信息表userinfo 字段名称 说明 备注 customerID 顾客编号 自动编号(标识列),从1开始,主键 用序列sequence实现,用其属性:nextval customerName 开户名 必填 PID 身份证号 必填,智能是18位或15位,唯一约束 check约束length()函数 telephone 联系电话 必填,11位手机号 check约束,’[0-9]’ address 居住地址 银行卡信息表cardinfo 字段名称 说明 cardID 卡号 必填,主键,银行的卡号规则和电话好吗一样,一般前8位代表特殊含义,如某综合某支行等,假定该行要求其营业厅的卡号格式为10103576**** ***开始,每4位号码后有空格,卡号一般是随机产生。 curType 货币种类 必填,默认为RMB savingTate 存款类型 活期/定活两便/定期 openDate 开户日期 必填,默认为系统当前日期 openMoney 开户金额 必填,不低于1元 balance 余额 必填,不低于1元,否则将销户 pass 密码 必填,6位数字,开户时默认为6个“6” IsReportloss 是否挂失 必填,是/否值,默认为“否” customerID 顾客编号 外键,必填,表示该卡对应的顾客编号,一位顾客允许办理多张卡号 交易信息表transinfo 字段名称 说明 transDate 交易日期 必填,默认为系统当前日期 cardID 卡号 必填,外键 transType 交易类型 必填,只能是存入/支取 transMoney 交易金额 必填,大于0 remark 备注 可选,其他说明 2、使用SQL语言在每个表上添加约束 主键约束、外键约束、CHECK约束、默认约束、非空约束 二、插入测试数据 使用SQL语言向每个表中插入至少3条记录 、模拟常规业务 1)修改客户密码 2)办理银行卡挂失 3)统计银行资金流通余额和盈利结算 银行资金流通余额=总存入金额-总支取金额 盈利结算=总支取金额 * 0.008 – 总存入金额 * 0.003 4)查询本周开户的卡号,显示该卡相关信息 5)查询本月交易金额最高的卡号 6)查询挂失账号的客户信息 四、利用视图实现数据查询 1)为客户提供以下3个视图供其查询该客户数据 客户基本信息:vw_userInfo 银行卡信息:vw_cardInfo 银行卡交易信息:vw_transInfo 2)提供友好界面,要求各列名称为中文描述 3)调用创建的视图获得查询结果 五、用存储过程实现业务处理 1)完成开户业务 2)完成取款或存款业务 3)根据卡号打印对账单 4)查询、统计指定时间段内没有发生交易的账户信息

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值