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

本文围绕数据库展开,介绍了表的创建,如学校信息表、班级表等,还设置了账户对部分表的增删改查权限以保护数据。同时设计了视图、触发器和存储过程,实现级联更新与删除。最后按规则进行数据载入,包括辅助表和主表信息插入。

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

grant select,insert,update,delete on StudentGerenInfor to zhongxuexiaozu

grant select,insert,update,delete on xuejiUpdate to zhongxuexiaozu

grant select,insert,update,delete on UserType to zhongxuexiaozu

grant select,insert,update,delete on BubieTable to zhongxuexiaozu

grant select,insert,update,delete on BiyeSheng to zhongxuexiaozu

–因为辅助表中除了SchoolInfor表与毕业生表给与zhongxuexiaozu账户授予一定的访问权限外,

–没有对其他例如年级、部别等表进行授予增删改查的权利,因为这些表是定死的,当二次开发时若需要,再次授权即可,应用程序连接DBMS时候是无法对SDbase数据库以外的数据库进行操作,也无法SDbase中没有授权的表进行操作,在一定程度上对数据进行了保护。

6.2表的建立与数据的载入

注释上的序号是创建表的顺序,因为主外键关系;其中序号为1的表为辅助表(建库的时候里面数据是定死的,后期进行二次开发时候可以再次进行开发使用。)

use SDbase

–1创建学校信息表

Create table SchoolInfor

(ScName VARCHAR(20) , --学校名称

Sprovince VARCHAR(20) not null,–学校所在省份

SbureauEd VARCHAR(20) not null,–学校所属教育局

Saddress varchar(50) not null,–学校地址

PRIMARY KEY(ScName)

)

–1部别信息表

Create table BubieTable(Bno char(1) unique ,Bname char(4) primary key)

–1年级信息表

Create table NianjiTable(Nno char(1) unique ,Nname char(6) primary key)

–1毕业生信息表

Create table BiyeSheng(

Sno char(12),

buBie char(10),

Sname varchar(36),

primary key(Sno)

)

–2班级表

Create table classTbale --班级表

(buBie char(4) , --类别初中、高中、小学等等

nianJi char(6),

banJi char(6) not null, --班级编号

TeacherNo varchar(12) unique NOT NULL, --老师编号

TeacherName varchar(50) not NULL,

primary key(buBie,nianJi,banJi),

foreign key(buBie) references BubieTable(Bname),

foreign key(nianJi) references NianjiTable(Nname),

)

–3入学信息表

Create table StudentInfor --创建学生入学基本信息表

(enrollmentYear char(4) not null,–考虑到年份都是四位数,所以定死为char(4)类型和大小

Sno char(12), --学生学号

buBie char(4) , --入学类型(初中、高中)

nianJi char(6),

banJi char(6),

Sname varchar(50) not null, --考虑到少数名族名字

Ssex char(2) check(Ssex in(‘男’,‘女’)),

Nationnality varchar(30) not null, --民族

placeBirth varchar(20)not null, --籍贯

birthDate Date not null, --出生日期

graduatedUniversity VARCHAR(20) not null,–毕业学校

enrollmentScore smallint check(enrollmentScore>=0),–总分

sourceUpdate char(10) not null, --来源/变动类型

muqianZhuangtai Varchar(30), --变动原因

PRIMARY KEY (Sno), --主键

foreign key(buBie) references BubieTable(Bname),

foreign key(nianJi) references NianjiTable(Nname),

)

–4创建学生个人情况

Create table StudentGerenInfor

(Sno char(12), --学号

mianMao char(12) not null, --政治面貌

shenTi char(10) , --身体状况

jiaTingRenKou char(2), --家庭人口

homeAdress VARCHAR(30) not null,–家庭住址

TemlePhone char(11) not null, --联系方式11位的手机号

PRIMARY KEY(Sno),

FOREIGN KEY (Sno) references StudentInfor(Sno)

)

–4创建学生主要关系表

Create table SGuanxi

(Sno char(12),

chengWei char(4), --与本人关系。,

Name varchar(50) NOT NULL, --姓名

Age CHAR(3) NOT NULL, --年龄

DanWei VARCHAR(50)NOT NULL, --单位

PRIMARY KEY (Sno,chengWei,Name), --考虑到一个人有多个家庭成员,但是可以有相同称谓的姐姐、弟弟,标识唯一一行

FOREIGN KEY (Sno) references StudentInfor(Sno)

)

–4学籍更改表

Create table xuejiUpdate

(

Sno char(12), --学号

updateType char(4), --变更类型

updateDate DATETime, --变更日期

yuanYin varchar(50), --变更原因

SendOrYanZheng VARCHAR(50), --发给或缴纳证件

PRIMARY KEY(Sno,updateDate),

foreign key (Sno) references StudentInfor(Sno)

)

–4创建系统用户

Create table UserType

(userID varchar(12), --用户名

userPassWord varchar(18), --账户实际操作人姓名

name varchar(50), --密码

dengJi char(1), --权限等级

shuoMing varchar(50), --权限说明

primary key (userID) --主键

)

6.3视图、触发器、存储过程设计

视图:

–用户权限视图

Create view User_type as

select userID as 账户,userPassWord as 密码 ,name as 姓名,dengji as 权限等级,

shuoMing as 权限说明 from UserType

应用程序通过嵌入SQL语句(用户模式:视图语句),一定程度上对数据的安全性进行了保护,

触发器:

–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’);

家庭信息插入:

–录入学生的家庭信息

最后

看完美团、字节、腾讯这三家的面试问题,是不是感觉问的特别多,可能咱们又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了1000道题目,多少还是有点用的呢,我看了下,上面这些问题大部分都能从我背的题里找到的,所以今天给大家分享一下互联网工程师必备的面试1000题

注意不论是我说的互联网面试1000题,还是后面提及的算法与数据结构、设计模式以及更多的Java学习笔记等,皆可分享给各位朋友

最新“美团+字节+腾讯”一二三面问题,挑战一下你能走到哪一面?

互联网工程师必备的面试1000题

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题

最新“美团+字节+腾讯”一二三面问题,挑战一下你能走到哪一面?

;

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

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

家庭信息插入:

–录入学生的家庭信息

最后

看完美团、字节、腾讯这三家的面试问题,是不是感觉问的特别多,可能咱们又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了1000道题目,多少还是有点用的呢,我看了下,上面这些问题大部分都能从我背的题里找到的,所以今天给大家分享一下互联网工程师必备的面试1000题

注意不论是我说的互联网面试1000题,还是后面提及的算法与数据结构、设计模式以及更多的Java学习笔记等,皆可分享给各位朋友

[外链图片转存中…(img-ePL12NBO-1714554168414)]

互联网工程师必备的面试1000题

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题

[外链图片转存中…(img-bEoBeIUa-1714554168415)]

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值