2023年7月27日发(作者:)
. . . . .
MySQL数据库设计
2012
. . . .
课程设计说明书
题 目: 驾校学员管理糸统
院 系:信息与智能工程糸
专业班级: 嵌入式技术与应用
学 号: **********
学生: 杰
指导教师:***
年1月9日 . . . . .
驾校学员管理系统
一.系统概述
驾校学员管理系统主要用于管理驾校的各种数据,利用这种mysql数据库的驾校管理系统可以给学员的管理资料的整理,资料的查询,数据的处理带来了很大的方便,能够很大的提高管理员的工作效率.
本系统主要用于管理学员的学籍信息/体检信息/成绩信息和驾驶证的领取信息等.这些信息的录入/查询/修改等操作都是该系统的重点解决的问题.
本系统分为5个管理部分,即用户的管理/秘籍信息管理/体检信息管理/成绩信息管理和领证信息管理.
本驾校学员管理系统的开发语言为java语言,选择的数据库是mysql.本系统是B/S架构的系统,需要web服务器tomcat
二.系统功能
驾校学员管理系统主要的功能是5个管理部分,即用户的管理/秘籍信息管理/体检信息管理/成绩信息管理和领证信息管理.本系统的管理模块如图所示
驾校学员管理糸统
用户信息管理学员学籍信息管理学员体检信息管理管理理学学员员成成绩绩信信息息管管理理学学员员领领証証信信息息管. . . .
. . . . .
图中模块的详细介绍如下:
用户信息管理:主要是对管理员的登录进行管理.管理员登录成功后,系统会进入到系统的管理界面.而且管理员可以修改自己的密码.
学籍信息管理:主要是对学生信息的插入/查询/修改和删除.查询学员的信息时,可以通过学号//报考的车型和学员的状态进行查询/通过这四个方面的处理,使学籍信息的管理更加的方便.
体检信息管理:主要对学员的体检信息的插入/查询/修改和删除.
成绩信息管理:对学员的学籍信息进行插入/查询/修改和删除等操作,以便有效的管理学员的成绩信息.
领证信息管理:对学员的驾驶证的领取进行管理.这部分主要是对学员的领证信息的插入/查询/修改和删除等操作.这样可以保证学员的驾驶证领取后,领取驾驶证的信息能够有效的管理.
三.数据库设计.
数据库设计是开发管理系统的一个重要的步骤,下面是数据库的设计过程.
数据库设计是要确定创建一些表/表中的字段/字段的数据类型和字段的长度.
1.设计表
本系统所有的表都放在drivingschool数据库下,创建drivingschool数据库的SQL代码如下:
CREATE DATABASE drivingschool;
运行的结果如图:表
. . . . . . . . .
user表中存储用户名和密码,所以将user表设计为只有两个字段.username字段表示用户名,password字段表示密码.因为用户名和密码都是字符串,所以这两个字段都是使用varchar类型.而且将这两个字段的长度都设置为20.而且用户名必须唯一.user表的每个字段的信息如表所示
字段名 字段描数据类型
述
主键 外键 非空 唯一
否
否
是
是
是
否
默认值
无
无
自增
Username 用户名 Varchar(20) 是
Password 密码
Varchar(20) 否
否
否
根据上表的容创建user表.创建user表的语句如下:
CREATE TABLE user(
Username varchar(20) primary key unique not null,
Password varchar(20) not null
);
创建完成后,可以使用desc语句来查询user表的结构,如图所示:
tinfo表
studentinfo表中主要的存放学员的学籍信息,包括学号//性别/年龄和号等信息.用sno字段表示学号,因为学号是studentinfo表的主建,所以sno字段是下能为空值的,而且必须是唯一的.identify字段表示学员的,而每个学员的必须是唯一的.因为在些的是以字母x结束的,所以identify字段设计为VARCHAR类型.
Sex字段表示为学员的性别,该字段只有”男”和”女”两种取值.因此sex字段使用enum类型.scondition字段表示学员的学业状态,每个学员只有3种状态,分别为”学习”/”结业”/”退学”.因此,scondition字段也使用enum类型.入学时间和毕业时间都是日期,因此选择date类型.s_text字段用于存储备注信息,所以选择text类型比较合适.studentinfo表的每个字段的信息如下表所示:
. . . . . . . . .
字段名 字段描述
Sno 学号
Sname
Sex 性别
Age 年龄
Identify 身份証号
tel
Car_type 报考车型
Enroll_time 入学时间
Leave_time 毕业时间
scondition 学业状态
S_text 备注
数据类型
Nit(8)
Varchar(20)
Enum
Int(3)
Varchar(18)
主键
是
否
否
否
否
外键
否
否
否
否
否
否
否
否
否
否
否
非空
是
是
是
否
是
否
是
是
否
是
否
唯一
是
否
否
否
是
否
否
否
否
否
否
默认值
无
无
无
无
无
无
无
无
无
无
无
自增
否
否
否
否
否
无
否
否
否
否
吞
Varchar(15) 否
Varchar(4) 否
date
date
enum
text
否
否
否
否
创建studentinfo表的sql代码如下:
Create table studentinfo(
Sno int(8) primary key unique not null,
Sname varchar(20) not null,
Sex enum(‘男’,’女’) not null,
Age int(3),
Identify varchar(18) unique not null,
Tel varchar(15),
Car_type varchar(4) not null,
Enroll_time date not null,
Leave_time date,
Scondition enum(‘学习’,’结业’,’退学’) not null,
S_text text
);
. . . . . . . . .
Studentinfo表创建在功以后,通过desc语句查看studentinfo表的结构,也可以通过show create table语句查看studentinfo表的详细信息,查看如图:
. . . . . . . . .
info表
因为驾校体检主要体检身高/体重/视力/听力/辡色能力/腿长和血压信息.所以heathinfo表中必须包含这些信息.身高/体重/左眼和石眼视力分别用height字段/weight字段/left_sight字段和right_sight字段表示.因为这些数值有些小数,所以这 些字段都定义成float类型.辡色能力/左耳听力/石耳听力/腿长和血压分别用differentiate字段/left_ear字段/right_ear字段/legs字段和pressuer字段表示.这些字段的取值都是在特定几个取值中取一个,因此定义成enum类型.
创建healthinfo表的SQL代码如下:
Create table healthinfo(
Id int(8) primary key unique not unll auto_increment,
Sno int(8) unique not null,
Sname varchar(20) not null,
Height float,
Weight float,
Differentiate enum(‘正常’,’色弱’,’色盲’),
Left_sight float,
Right_sight float,
Left_ear enum(‘正常’,’偏弱’),
Right_ear enum(‘正常’,’偏弱’),
Legs enum(‘正常’,’不相等’),
. . . . . . . . .
Pressure enum(‘正常’,’偏高’,’偏低’),
History varchar(50),
H_text text,
Constraint health_fk foreign key(sno)
References studentinfo(sno)
);
创建healthinfo表时将sno字段设置为外键,而且外键的别名为health_fk.而且,id字段加上了auto_increment属性,这样就可以将id字段设置为自增字段.
表建好了后用desc语句查询,如下:
info表
. . . . . . . . .
Courseinfo表用于存储考试科目的信息,每个科目都必须有科目号/科目名称.这个表只需要3个字段就可以了,cno字段表示科目号,cname字段表示科目名称,before_cour字段表示先行考试的科目号.每条记录中,只有before_cour字段中存储的科目考试通过后,学员才可以报考cno表示的科目.courseinfo表的每个字段的信息如下
字段名 字段描述
Cno 科目号
Cname 科目名称
Before_cour 先行考试科目
创建courseinfo表的sql代码如下:
Create table courseinfo(
Cno int(4) primary key not null unique,
Cname varchar(20) not null unique,
Before_cour int(4) not null default 0
);
Courseinfo表创建完成后用desc语句查询,如下图:数据类型
Int(4)
主键 外键 非空 唯一 默认值
是 否 是 是 无
否
否
是
是
是
否
无
0
自增
否
否
否
Varchar(20) 否
Int(4) 否
nfo表
Gradeinfo表用于存储学员的成绩信息.这个表必须和student和course表建立联糸.因此设计sno字段和cno字段.sno字段和cno字段作为外键.sno字段依赖于studentinfo表的sno字段,cno字段依赖于courseinfo表的cno字段.这里用time字段表示某一个科目的考试次数.默认的情况下是第一次参加考试,因此times字段的默认值为1.分数用grade字段表示,默认分数为0分.它的每. . . . . . . . .
个字段的信息如下图所示:
创建gradeinfo表的sql代码如下:
Create table gradeinfo(
Id int(8) primary key unique not null auto_increment,
Sno int(8) not null,
Cno int(4) not null,
Last_time date,
Times int(4) default 1,
Grade float default 0,
Constraint grade_sno_fk foreign key (sno)
References studentinfo(sno),
Constraint grade_cno_fk foreign key (cno)
References courseinfo(cno)
);
代码执行后,在sno字段被设置成外键,该外键的别名为grade_sno_fk.同时,cno字段也被设置成外键,改外键的别名为grade_cno_fk.用desc语句查询gradeinfo表的结构如下图:
. . . . . . . . .
einfo表
Licenseinfo表用于存储学员领取驾驶证的信息.这个表中需要记录学员的学号//驾驶证/领取的时间/领取人等信息.
驾驶证用lno字段表示,每个人的驾驶証号都是唯一的.licenseinfo表的每个字段的信息如下图所示:
创建licenseinfo表的sql代码如下:
Create table licenseinfo(
Id int(8) primary key unique not null auto_increment,
Sno int(8) unique not null,
Sname varchar(20) not null,
Lno varchar(18) unique not null,
Receive_time date,
Receive_name varchar(20),
L_text text,
Constraint license_fk foreign key (sno)
References studentinfo(sno)
);
. . . . . . . . .
Sno字段设置成外键,该外键的别名为license_info表创建完成后,使用desc语句查询licenseinfo表的如构如下图:
1. 在studentinfo表上建立索引
下面使用create index语句在sname初段上创建名为index_stu_name的索引.sql代码如下:
Create index index_stu_name on studentinfo(sname);
Create index index_car on studentinfo(car_type);
使用alter table语句在scondition字段上创建名为index_con的索引.sql代码如下:
Alter table studentinfo add index index_con(scondition);
代码执行完了后,使用show create table语句查看studentinfo表的结构.查看结果中如果显示了index_stu_naem和index_car和index_con这3个. . . . . . . . .
索引,这表示索引已经创建成功了:
. . . .
发布者:admin,转转请注明出处:http://www.yc00.com/news/1690429555a348724.html
评论列表(0条)