中学学籍管理系统数据库课程设计,限于篇幅只能采取截图方式上传,原文件在我资源中有所展示。(1)

本文围绕中学学籍管理数据库展开,介绍了触发器、存储过程的创建,如根据入学成绩设置录取类型、毕业时发放毕业证等。还提及级联更新与删除、数据载入原则及操作,阐述了数据库各表的运行逻辑,最后给出应用系统登录的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

触发器:

–1当学生入学成绩成绩小于460时候,学生的录取类型为借读生。

CREATE TRIGGER Student_fenshu ON StudentInfor --该触发器建在学生入学表生

FOR INSERT --触发器类型 插入记录时候

as

declare e1 cursor for

select Sno,enrollmentScore,muqianZhuangtai from inserted --触发器名称 e1

declare @Sno char(12)

declare @enrollmentScore smallint

declare @sourceUpdate char(10)

OPEN e1

fetch NEXT FROM e1 into @Sno,@enrollmentScore,@sourceUpdate

WHILE @@FETCH_STATUS=0 – 当返回值为0时候继续执行Begin下语句,知道返回值为-1或者非0

BEGIN

IF @enrollmentScore <=460 --入过入学分数小于或者等于460

update StudentInfor set sourceUpdate=‘借读’ --把当前已经输入的入读类型为借读,即使之前是其他也会更改为借读

where @Sno=Sno

fetch next from e1 into @Sno,@enrollmentScore,@sourceUpdate --条件为0时候继续遍历临时表中的记录,知道条件为非0

end

close e1 --遍历游标 e1

DEALLOCATE e1 --释放游标

–2学籍管理,当学生毕业时候,在学籍变动表中,为学生发放毕业证

Create TRIGGER Student_biye ON xuejiUpdate

FOR insert --触发器类型 插入记录时候

as

declare e_biye cursor for

select Sno,updateType,SendOrYanZheng from inserted

declare @Sno varchar(36)

declare @updateType char(4)

declare @SendOrYanZheng VARCHAR(50)

OPEN e_biye

fetch NEXT FROM e_biye into @Sno,@updateType,@SendOrYanZheng

WHILE @@FETCH_STATUS=0

BEGIN

if @updateType=‘毕业’ --如果学籍异动表中出现一个新的异动类型为毕业

BEGIN

update xuejiUpdate set SendOrYanZheng=‘发给毕业证’ where @Sno=Sno --那么发给毕业证

END

fetch next from e_biye into @Sno,@updateType,@SendOrYanZheng

end

close e_biye

DEALLOCATE e_biye

–3当学生状态为毕业状态时候,自动把所有毕业生的信息导入到一张毕业生表中去。

CREATE TRIGGER biye_tig ON StudentInfor

FOR update

as

declare e_insertBiye cursor for select Sno,Sname,buBie,sourceUpdate from inserted

declare @Sno char(12)

declare @Sname varchar(36)

declare @buBie char(4)

declare @sourceUpdate char(10)

OPEN e_insertBiye

fetch NEXT FROM e_insertBiye into @Sno,@Sname,@buBie,@sourceUpdate

WHILE @@FETCH_STATUS=0

BEGIN

–当我更改变动类型时候,而且满足变动类型为毕业,那么毕业生信息导入到毕业生到BiyeSheng表中

if update(sourceUpdate) and @sourceUpdate=‘毕业’

insert into BiyeSheng values(@Sno,@Sname,@buBie)

fetch next from e_insertBiye into @Sno,@Sname,@buBie,@sourceUpdate

end

close e_insertBiye

DEALLOCATE e_insertBiye

–4当学生学籍状态发生改变时候例如请假转班或者进行毕业,

–把学籍异动信息进行存储到学籍异动表中,每次变动都会添加一条记录,主键是学号+日期。

Create TRIGGER Student_baingeng ON StudentInfor

FOR update

as

declare e cursor for select Sno,muqianZhuangtai,sourceUpdate from inserted

declare @Sno varchar(36)

declare @muqianZhuangtai char(10)

declare @sourceUpdate char(10)

OPEN e

fetch NEXT FROM e into @Sno,@muqianZhuangtai,@sourceUpdate

while @@FETCH_STATUS=0

BEGIN

if update(sourceUpdate)

BEGIN

insert into xuejiUpdate values(@Sno,@sourceUpdate,getDate(),@muqianZhuangtai,‘无’)

END

fetch next from e into @Sno,@muqianZhuangtai,@sourceUpdate

end

close e

DEALLOCATE e

–5当学校录取一名学生时候,为该生创建一个学籍管理系统的学生账户。

CREATE TRIGGER Student_Chufa ON StudentInfor

FOR INSERT

as

declare e cursor for select Sno,Sname from inserted

declare @Sno varchar(36)

declare @Sname varchar(36)

OPEN e

fetch NEXT FROM e into @Sno,@Sname

WHILE @@FETCH_STATUS=0

BEGIN

–创建账户,的登录账户为学号,姓名为学生姓名,权限代码为4,默认为学生

insert into UserType values(@Sno,123456,@Sname,4,‘学生’)

fetch next from e into @Sno,@Sname

end

close e

DEALLOCATE e

–6创建一个新班级时候,为该班班主任老师授予查询该班学生信息的权利

CREATE TRIGGER Class_Table ON classTbale

FOR INSERT

as

declare e cursor for select TeacherNo,TeacherName from inserted

declare @TeacherNo varchar(12)

declare @TeacherName varchar(50)

OPEN e

fetch NEXT FROM e into @TeacherNo,@TeacherName

WHILE @@FETCH_STATUS=0

BEGIN

insert into UserType values(@TeacherNo,123456,@TeacherName,2,‘老师’)

fetch next from e into @TeacherNo,@TeacherName

end

close e

DEALLOCATE e

存储过程

创建存储过程:

–创建一个查询系统用户表存储过程.

Create procedure Select_UserType

as

begin

select userID,userPassWord,name,dengJi,shuoMing from UserType

set nocount on;

end

Go

执行存储过程:

USE [SDbase]

GO

DECLARE @return_value int

EXEC @return_value = [dbo].[Select_UserType]

SELECT ‘Return Value’ = @return_value

GO

执行结果:

级联更新与删除:

当我们要从数据库中删除一个学生的信息时候,要同时删除4张表的信息(学生入学表信息,学生的家庭关系,学生个人情况,以及学生学籍变动情况表),按原则上讲师需要对学生的访问系统账户一通删除的,但是本系统的学生用户表(系统用户表中包含学生老师与其他管理员信息)没有与学生入学表进行建立级联删除与更新,因为用户表没有与学生入学表建立参照关系,这是一个重要的原因,其次原因是因为,表中还拥有老师与管理员的数据,要想实现当删除学生的时候同时也删除学生的账户,可以把学生账户与系统账户所分开,或者通过应用程序段建立删除,本系统是在建立完物理逻辑结构后,通过修改列级约束进行添加的。

–对参照StudentInfor学生入学表的表建立级联更新与删除

alter table StudentGerenInfor add constraint a_Sno foreign key(Sno) references StudentInfor(Sno) on delete cascade

alter table SGuanxi add constraint b_Sno foreign key(Sno) references StudentInfor(Sno) on delete cascade

alter table xuejiUpdate add constraint c_Sno foreign key(Sno) references StudentInfor(Sno) on delete cascade

数据载入:

数据载入遵循,被参照表先进行插入的原则,数据删除是参照表先删除原则,两者相反。

辅助表的信息先插入,因为主表的信息都是与辅助表的关系是参照表与被参照表的关系,

所以辅助表先插入

辅助表数据插入:

–1插入学校信息(学校名称、所在省份、所属教育局、学校地址)

insert into SchoolInfor values(‘黄石理工附中’,‘湖北省’,‘黄石市教育局’,‘黄石市下陆区团城山街道’)

insert into SchoolInfor values(‘黄石二中’,‘湖北省’,‘黄石市教育局’,‘黄石市下陆区扬州路’)

–1插入部别表

insert into BubieTable values(1 ,‘初中’)

insert into BubieTable values(2 ,‘高中’)

insert into BubieTable values(3,‘小学’)

–1插入年级表

insert into NianjiTable values(1 ,‘一年级’)

insert into NianjiTable values(2 ,‘二年级’)

insert into NianjiTable values(3 ,‘三年级’)

insert into NianjiTable values(4 ,‘四年级’)

insert into NianjiTable values(5 ,‘五年级’)

insert into NianjiTable values(6 ,‘六年级’)

–1插入学校信息(学校名称、所在省份、所属教育局、学校地址)

insert into SchoolInfor values(‘黄石理工附中’,‘湖北省’,‘黄石市教育局’,‘黄石市下陆区团城山街道’)

insert into SchoolInfor values(‘黄石二中’,‘湖北省’,‘黄石市教育局’,‘黄石市下陆区扬州路’)

主表信息插入:

–插入班级表(部别、年级、班级编号、老师编号、老师姓名)

insert into classTbale values(‘高中’,‘一年级’,‘一班’,‘10088’,‘扬眉老师’);

insert into classTbale values(‘高中’,‘一年级’,‘二班’,‘10089’,‘镇元子老师’);

insert into classTbale values(‘高中’,‘二年级’,‘一班’,‘20099’,‘孙悟空老师’);

insert into classTbale values(‘初中’,‘一年级’,‘一班’,‘11088’,‘菩提祖师’);

insert into classTbale values(‘初中’,‘二年级’,‘一班’,‘12088’,‘如来佛祖’);

–插入学生信息(入学年份(4位)、学号(12位)、入学类型、年级、班级、姓名、性别(男/女)、民族、籍贯、出生日期、毕业学校、总分、来源、变动原因)

–学校录取学生时候,由招生办老师提供的名单,当录取学生的时候,

–同时为该学生提供一个系统账户,账户名为学生的学号,密码默认为123456,账户类型为学生账户

insert into StudentInfor values(‘2020’,‘202020491111’,‘初中’,‘一年级’,‘1’,‘余欣’,‘女’,‘汉族’,‘襄阳’,‘1999-01-28’,‘湖北理工’,‘480’,‘录取’,‘无’);

insert into StudentInfor values(‘2016’,‘201616491110’,‘初中’,‘二年级’,‘2’,‘张一’,‘男’,‘汉族’,‘恩施’,‘1997-11-06’,‘湖北理工’,‘490’,‘录取’,‘无’);

insert into StudentInfor values(‘2017’,‘201717491101’,‘初中’,‘三年级’,‘3’,‘张二’,‘女’,‘汉族’,‘十堰’,‘1998-01-01’,‘湖北理工’,‘510’,‘休学’,‘无’);

insert into StudentInfor values(‘2020’,‘202020491155’,‘高中’,‘一年级’,‘1’,‘张四’,‘女’,‘汉族’,‘宣恩’,‘2000-01-11’,‘湖北理工’,‘489’,‘休学’,‘无’);

insert into StudentInfor values(‘2017’,‘201717491170’,‘高中’,‘二年级’,‘2’,‘张五’,‘女’,‘汉族’,‘洛阳’,‘1997-12-25’,‘湖北理工’,‘490’,‘录取’,‘无’);

insert into StudentInfor values(‘2018’,‘201616491180’,‘高中’,‘三年级’,‘3’,‘张六’,‘女’,‘汉族’,‘商丘’,‘1998-03-03’,‘湖北理工’,‘470’,‘录取’,‘无’);

个人信息插入:

–录入学生的个人情况

insert into StudentGerenInfor values(‘202020491111’,‘团员’,‘健康’,‘5’,‘襄阳’,‘10010100861’);

insert into StudentGerenInfor values(‘201616491110’,‘团员’,‘健康’,‘3’,‘恩施’,‘10086100861’);

insert into StudentGerenInfor values(‘201717491101’,‘群众’,‘健康’,‘4’,‘十堰’,‘10011100861’);

insert into StudentGerenInfor values(‘202020491155’,‘党员’,‘健康’,‘7’,‘宣恩’,‘10086100101’);

insert into StudentGerenInfor values(‘201717491170’,‘团员’,‘健康’,‘8’,‘洛阳’,‘10010100101’);

insert into StudentGerenInfor values(‘201616491180’,‘团员’,‘健康’,‘4’,‘商丘’,‘10011100811’);

家庭信息插入:

–录入学生的家庭信息

insert into SGuanxi values(‘202020491111’,‘陈思’,‘母亲’,‘43’,‘在家’);

insert into SGuanxi values(‘202020491111’,‘陈十’,‘父亲’,‘43’,‘在家’);

insert into SGuanxi values(‘201616491110’,‘陈一’,‘母亲’,‘40’,‘在家’);

insert into SGuanxi values(‘201616491110’,‘陈二’,‘母亲’,‘40’,‘在家’);

insert into SGuanxi values(‘201717491101’,‘陈三’,‘母亲’,‘43’,‘在家’);

insert into SGuanxi values(‘201717491101’,‘陈五’,‘母亲’,‘40’,‘在家’);

insert into SGuanxi values(‘202020491155’,‘王一’,‘母亲’,‘40’,‘在家’);

insert into SGuanxi values(‘202020491155’,‘王二’,‘父亲’,‘40’,‘在家’);

insert into SGuanxi values(‘202020491155’,‘王三’,‘姐姐’,‘25’,‘在家’);

insert into SGuanxi values(‘201717491170’,‘陈六’,‘母亲’,‘40’,‘在家’);

insert into SGuanxi values(‘201717491170’,‘陈七’,‘父亲’,‘42’,‘在家’);

insert into SGuanxi values(‘201616491180’,‘陈八’,‘母亲’,‘43’,‘在家’);

insert into SGuanxi values(‘201616491180’,‘陈九’,‘母亲’,‘43’,‘在家’);

6.4 数据库的运行

本系统的物理逻辑设计(表设计):分为主表和辅助表。

其中辅助表中的信息分为系统的基本信息,和导入表.

导入表:

(例如本系统中的毕业生表,可以通过把毕业生信息直接导入EXEL文件,显示或者建立视图等等,另毕业生表的信息市通过触发器来实现导入的,当学生的状态为毕业时候会自动导入。);

基本信息:例如一个学校办学类型,例如小学初中高中,或者中职等,该功能可以通过系统设计之初,就已经定死,本系统是定死的,二次开发时候,我们可以通过在应用程序端对这些辅助表的信息进行一些操作来增加学校的学习类型更改,例如:

学校信息表:

学校信息表并没有与学生建立关联关系,一个重要原因是是学校信息表主要是

为了系统的使用者所查看,是为了方便二次开发所建立,或者当系统(成熟)连入互联网后,形成上级教育机构(教育局)与下级(学校)形成父子关系时候,方便上级部门查看该学校的信息,等等,但是前提是访问者需要拥有一定的权限,这个时候系统要考虑要不要把上级教育机构和下级教育机构的数据(例如用户表数据)进行分离,学校数据在一定情况下是不用分离

的,但是考虑到未来某地大量使用该系统肯定存在一个教育机构管理多个下属学校,数据量大的时候。

在这里插入图片描述

部别表:

学校的办学类型,系统建立之初已经定死,或者二次开发对该表操作。

在这里插入图片描述

年级表:

其中年级表,建立了存储过程保证了当学生入学类型是初中和高中时候,能选择例如高中四年级或者初中四年级,而只能是小学四年级、五年级等等。

在这里插入图片描述

毕业生表:

该表是当学生入学表中,sourceUpdate,学生状态更新为毕业生时候,自动触发导入的。

当学生入学表中sourceUpdate发生改变为毕业生时候:

在这里插入图片描述

向毕业生表中导入数据。

在这里插入图片描述

以下是主表运行

班级表:

班级建立后为班级设立班主任同时,为该班主任通过触发器建立一个权限账户,用来管理该班的学生。

在这里插入图片描述

系统用户表:

该表中的用户类型分为学生和老师以及管理员或者其他(可能是年级主任或者以他工作人员),其中学生与老师的账户是当班级建立和学生录取时候通过触发器,自动为老师分配一个账户,学生的账户在本系统中只拥有查询本人信息的权利,管理员账户以及其他权限账户通过管理员进行添加或者设置。

在这里插入图片描述

学生入学信息表:

该表是其他3张表Sno的外键,是被参照表,通过与其他三张表(学生个人情况,家庭情况情况表,学籍变动情况表)建立级联更新与删除,来保证数据的完整性。

在这里插入图片描述

学生个人情况表:

通过Sno与学生入学表建立主外键关系,同时建立级联更新与级联删除,级联更新是可能存在更新学号的情况下,级联删除是为了在一定的情况下删除该生信息。

在这里插入图片描述

学生家庭信息表:

通过Sno与学生入学表建立主外键关系,同时建立级联更新与级联删除,级联更新是可能存在更新学号的情况下,级联删除是为了在一定的情况下删除该生信息。

在这里插入图片描述

学生学籍变动表:

学籍变动表不需要人为进行录入,学籍变动表是记录学生学籍在校期间,学籍变动情况,通过更改学生入学表的sourceupdate(来源)触发器实现的,信息录入,为了保证数据的完整性,对Sno和日期建立主键,其中Sno参照入学表的Sno保证了跟踪每一名学生的在变动情况。另外,当学生变动类型为毕业时候,会发放一张毕业证。

在这里插入图片描述

第七章 应用系统开发

在这里插入图片描述

DBMS中系统用户表中数据如下:

在这里插入图片描述

中学学籍管理系统系统登录窗口:

输入项:账户、密码

输出项:通过select 查询语句把该账户信息传递到后台的应用程序中,我们这个时候可以

判断该账户的实际用户人以及权限,当进入主程序界面后把账户人姓名显示,且根据不同账户等级显示不同的界面。

应用程序代码如下:

//当点击登录按钮时候执行下面语句

if (e.getSource()==an1) {

//接收外部实体用户输入的账户信息

String UserID=center.getText();

//接受外部实体用户输入的密码

String UserPassWord=mima.getText();

try {

//调用类GetConnection里面的getConn()方法链接数据库

conn=GetConnection.getConn();

stat=conn.createStatement();

把查询到的结果集放入到rs中

rs= stat.executeQuery(“SELECT * FROM User_type where 账户='”+UserID+“'”);

//定义一个循环,当循环的值为非-1时候继续执行,等-1停止循环遍历

while(rs.next()) {

//判断当前rs所取到的一条结果集中第二个字段(密码)是否等于根据我所输入的账户所查询得出的值

if (rs.getString(2).equals(UserPassWord)) {

//如果相等,那么口令正确,让其进行主界面(zhuJieMian)

最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

image

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!

rd=mima.getText();

try {

//调用类GetConnection里面的getConn()方法链接数据库

conn=GetConnection.getConn();

stat=conn.createStatement();

把查询到的结果集放入到rs中

rs= stat.executeQuery(“SELECT * FROM User_type where 账户='”+UserID+“'”);

//定义一个循环,当循环的值为非-1时候继续执行,等-1停止循环遍历

while(rs.next()) {

//判断当前rs所取到的一条结果集中第二个字段(密码)是否等于根据我所输入的账户所查询得出的值

if (rs.getString(2).equals(UserPassWord)) {

//如果相等,那么口令正确,让其进行主界面(zhuJieMian)

最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

[外链图片转存中…(img-qsv2uPFC-1714554142530)]

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值