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)]