数据库原理及应用实验.docx
- 文档编号:5011799
- 上传时间:2022-12-12
- 格式:DOCX
- 页数:20
- 大小:161.72KB
数据库原理及应用实验.docx
《数据库原理及应用实验.docx》由会员分享,可在线阅读,更多相关《数据库原理及应用实验.docx(20页珍藏版)》请在冰豆网上搜索。
数据库原理及应用实验
《数据库原理及应用》实验
姓名黄鸿波学号3100717208班别计本10-2
数据库原理及应用(本科)
实验指导书
-计算机信息教研室-
桂林理工大学信息科学与工程学院
二○一二年五月
目录
实验1创建数据库与数据表……………………………………………………………2
实验2简单查询和连接查询……………………………………………………………10
实验3嵌套查询和集合查询……………………………………………………………12
实验4数据完整性………………………………………………………………………14
时间:
机房号:
得分:
实验1创建数据库与数据表
实验目的:
1.熟悉SQLSERVER环境;
2.掌握数据库和数据表的创建和删除,实践SQL的CREATE、ALTER和DROP命令;
3.掌握数据表的创建和数据记录的插入方法。
实验内容:
1.创建教学管理“JXGL”数据库,并建立学生STUDENT、课程COURSE和选修SC三个数据表,各表中的数据如下所示:
学生STUDENT:
Sno
Sname
Ssex
Sage
Sdept
95001
李勇
M
20
CS
95002
刘晨
F
19
IS
95003
王敏
F
18
MA
95004
张立
M
18
IS
课程COURSE:
Cno
Cname
Cpno
Ccredit
1
数据库
5
4
2
数学
2
3
信息系统
1
4
4
操作系统
6
3
5
数据结构
7
4
6
数据处理
2
7
C语言
6
4
选修SC:
Sno
Cno
Grade
95001
1
92
95001
2
85
95001
3
88
95002
2
90
95002
3
80
2.创建供应系统“GYXT”数据库,其中包括供应商表S、零件表P、工程项目表J和供应情况表SPJ四个数据表,各表中数据如下所示。
供应商S:
SNO
SNAME
CITY
S1
精益
天津
S2
万胜
北京
S3
东方
北京
S4
丰泰隆
上海
S5
康健
南京
零件P:
PNO
PNAME
COLOR
WEIGHT
P1
螺母
红
12
P2
螺栓
绿
17
P3
螺丝刀
蓝
14
P4
螺丝刀
红
14
P5
凸轮
蓝
40
P6
齿轮
红
30
工程项目J:
JNO
JNAME
CITY
J1
三建
北京
J2
一汽
长春
J3
弹簧厂
天津
J4
造船厂
天津
J5
机车厂
唐山
J6
无线电厂
常州
J7
半导体厂
南京
供应情况SPJ:
SNO
PNO
JNO
QTY
S1
P1
J1
200
S1
P1
J3
100
S1
P1
J4
700
S1
P2
J2
100
S2
P3
J1
400
S2
P3
J2
200
S2
P3
J4
500
S2
P3
J5
400
S2
P5
J1
400
S2
P5
J2
100
S3
P1
J1
200
S3
P3
J1
200
S4
P5
J1
100
S4
P6
J3
300
S4
P6
J4
200
S5
P2
J4
100
S5
P3
J1
200
S5
P6
J2
200
S5
P6
J4
500
实验步骤:
1.创建教学管理“JXGL”数据库。
(注:
可采用可视窗体和SQL命令两种方法创建。
以下是SQL命令方法)
(1)创建教学管理“JXGL”数据库。
在命令窗格中输入如下命令,然后单击“运行”钮执行该命令。
CREATEDATABASEJXGL;
(2)清空命令窗格后,在JXGL数据库中建立STUDENT表,并插入记录,然后执行。
CREATETABLESTUDENT
(Snochar(5)notnullunique,
Snamechar(20)notnullunique,
Ssexchar
(1),
Sageint,
Sdeptchar(20));
INSERTINTOSTUDENTVALUES(‘95001’,’李勇’,’M’,20,’CS’);
INSERTINTOSTUDENTVALUES(‘95002’,’刘晨’,’F’,19,’IS’);
INSERTINTOSTUDENTVALUES(‘95003’,’王敏’,’F’,18,’MA’);
INSERTINTOSTUDENTVALUES(‘95004’,’张立’,’M’,18,’IS’);
(3)清空查询窗格后,JXGL数据库中建立COURSE表,并插入记录,然后执行。
CREATETABLECOURSE
(Cnochar
(2)notnullPRIMARYKEY(Cno),
Cnamechar(20),
Cpnochar
(2),
Ccreditsmallint);
INSERTINTOCOURSEVALUES(‘1’,’数据库’,’5’,4);
INSERTINTOCOURSEVALUES(‘2’,’数学’,’’,2);
INSERTINTOCOURSEVALUES(‘3’,’信息系统’,’1’,4);
INSERTINTOCOURSEVALUES(‘4’,’操作系统’,’6’,3);
INSERTINTOCOURSEVALUES(‘5’,’数据结构’,’7’,4);
INSERTINTOCOURSEVALUES(‘6’,’数据处理’,’’,2);
INSERTINTOCOURSEVALUES(‘7’,’C语言’,’6’,4);
(4)清空查询窗格后,JXGL数据库中建立SC表,并插入记录,然后执行。
CREATETABLESC
(Snochar(5)notnull,
Cnochar
(2)notnull,
Gradesmallint,
PRIMARYKEY(Sno,Cno),
FOREIGNKEY(Sno)REFERENCESSTUDENT(Sno),
FOREIGNKEY(Cno)REFERENCESCOURSE(Cno));
INSERTINTOSCVALUES(‘95001’,‘1’,92);
INSERTINTOSCVALUES(‘95001’,‘2’,85);
INSERTINTOSCVALUES(‘95001’,‘3’,88);
INSERTINTOSCVALUES(‘95002’,‘2’,90);
INSERTINTOSCVALUES(‘95002’,‘3’,80);
(5)查看三个表中的内容。
分别执行以下命令,查看STUDENT、COURSE和SC数据表中的内容。
SELECT*FROMSTUDENT;
SELECT*FROMCOURSE;
SELECT*FROMSC;
(6)ALTERTABLE、DROPTABLE、DROPDATABASE命令运用。
①向STUDENT表增加“入学时间”列,其数据类型为日期型,用SELECT命令查看表中内容。
ALTERTABLESTUDENTADDSCOMEDATETIME;
SELECT*FROMSTUDENT;
②删除“入学时间”列,再用SELECT命令查看表中内容。
ALTERTABLESTUDENTDROPCOLUMNSCOME;
SELECT*FROMSTUDENT;
③删除数据表。
DROPTABLESC;
DROPTABLESTUDENT;
DROPTABLECOURSE;
④删除数据库命令。
切换到其他任意数据库,然后可用如下命令删除JXGL数据库。
DROPDATABASEJXGL;
重复
(1)~(4)过程,建立数据库备以后的查询使用。
2.创建供应系统“GYXT”数据库。
(注:
可采用可视窗体和SQL命令两种方法创建。
)
下面写出实现如下操作的SQL语句:
(1)创建供应系统“GYXT”数据库。
CREATEDATABASEGYXT;
(2)建立供应商表S。
CREATETABLES
(SNOCHAR(5)PRIMARYKEY,
SNAMECHAR(6)NOTNULL,
CITYCHAR(10)NOTNULL
);
(3)建立零件表P。
CREATETABLEP
(PNOCHAR
(2)PRIMARYKEY,
PNAMECHAR(6)NOTNULL,
COLORCHAR
(2)DEFAULT('红'),
WEIGHTINT,
);
(4)建立工程项目表J。
CREATETABLEJ
(JNOCHAR(5)PRIMARYKEY,
JNAMECHAR(10)NOTNULL,
CITYCHAR(10)NOTNULL
);
);*/
CREATETABLESPJ(5)建立供应情况表SPJ。
CREATETABLESPJ
(SNOchar(5)notnull,
PNOchar
(2)notnull,
JNOchar(5)notnull,
QTYint,
PRIMARYKEY(SNO,PNO,JNO),
FOREIGNKEY(SNO)REFERENCESS(SNO),
FOREIGNKEY(PNO)REFERENCESP(PNO),
FOREIGNKEY(JNO)REFERENCESJ(JNO),
);
(6)应用INSERTINTO命令将相应数据写入到供应商表S、零件表P、工程项目表J和供应情况表SPJ四个数据表。
INSERTINTOSVALUES('S1','精益','天津');
INSERTINTOSVALUES('S2','万胜','北京');
INSERTINTOSVALUES('S3','东方','北京');
INSERTINTOSVALUES('S4','丰泰隆','上海');
INSERTINTOSVALUES('S5','南京','南京');*/
INSERTINTOPVALUES('P1','螺母','红','12');
INSERTINTOPVALUES('P2','螺栓','绿','17');
INSERTINTOPVALUES('P3','螺丝刀','蓝','14');
INSERTINTOPVALUES('P4','螺丝刀','红','14');
INSERTINTOPVALUES('P5','凸轮','蓝','40');
INSERTINTOPVALUES('P6','齿轮','红','30');
INSERTINTOJVALUES('J1','三建','北京');
INSERTINTOJVALUES('J2','一汽','长春');
INSERTINTOJVALUES('J3','弹簧厂','天津');
INSERTINTOJVALUES('J4','造船厂','天津');
INSERTINTOJVALUES('J5','机车厂','唐山');
INSERTINTOJVALUES('J6','无线电厂','常州');
INSERTINTOJVALUES('J7','半导体厂','南京'
INSERTINTOSPJVALUES('S1','P1','J1','200');
INSERTINTOSPJVALUES('S1','P1','J3','100');
INSERTINTOSPJVALUES('S1','P1','J4','700');
INSERTINTOSPJVALUES('S1','P2','J2','100');
INSERTINTOSPJVALUES('S2','P3','J1','400');
INSERTINTOSPJVALUES('S2','P3','J2','200');
INSERTINTOSPJVALUES('S2','P3','J4','500');
INSERTINTOSPJVALUES('S2','P3','J5','400');
INSERTINTOSPJVALUES('S2','P5','J1','400');
INSERTINTOSPJVALUES('S2','P5','J2','100');
INSERTINTOSPJVALUES('S3','P1','J1','200');
INSERTINTOSPJVALUES('S3','P3','J1','200');
INSERTINTOSPJVALUES('S4','P5','J1','100');
INSERTINTOSPJVALUES('S4','P6','J3','300');
INSERTINTOSPJVALUES('S4','P6','J4','200');
INSERTINTOSPJVALUES('S5','P2','J4','100');
INSERTINTOSPJVALUES('S5','P3','J1','200');
INSERTINTOSPJVALUES('S5','P6','J2','200');
INSERTINTOSPJVALUES('S5','P6','J4','500');
时间:
机房号:
得分:
实验2简单查询和连接查询
实验目的:
1.熟练掌握SQLServer查询分析器的使用方法,加深对标准SQL查询语句的理解。
2.熟练掌握简单表的数据查询、数据排序和数据连接查询的操作方法。
实验内容:
1.基于实验一创建的教学管理JXGL数据库,实现数据的基本查询操作。
2.基于实验一创建的供应系统GYXT数据库,实现数据的基本查询操作。
实验步骤:
写出下列操作的SQL语句。
1.在教学管理JXGL数据库中进行如下操作:
(1)求数学系学生的学号和姓名。
USEJXGL
SELECTSno,Sname
FROMSTUDENT
WHERESdept='MA';
(2)求选修了课程的学生学号。
USEJXGL
SELECTdistinctSno
FROMsc;
(3)求选修了数学课的学生学号和成绩,并要求对查询结果按成绩降序排列,如果成绩相同则按学号升序排列。
SELECTSno,Grade
FROMSC
WHERECno=2
ORDERBYGradeDESC,SnoASC;
(4)求选修数学课其且成绩在80-90之间的学生学号和成绩,并将成绩乘以系数0.8输出。
SELECTSno,Grade=0.8*Grade
FROMSC
WHERECno=2ANDGradeBETWEEN80AND90
ORDERBYGradeDESC,SnoASC;
(5)求数学系或计算机系姓刘的学生的信息。
SELECT*
FROMSTUDENT
WHERESnameLIKE'刘%'AND(Sdept='MA'ORSdept='IS')
(6)求缺少了成绩的学生的学号和课程号。
SELECTSno,Cno
FROMSC
WHEREGradeISNULL;
(7)查询每个学生的情况以及他(她)所选修的课程。
SELECTSTUDENT.Sno,SnameSsex,Sage,Sdept,SC.Cno,Grade,Cname
FROMSTUDENT,SC,COURSE
WHERESTUDENT.Sno=SC.SnoANDCOURSE.Cno=SC.Cno
(8)求学生的学号、姓名、选修的课程名及成绩。
SELECTSTUDENT.Sno,Sname,Grade,Cname
FROMSTUDENT,SC,COURSE
WHERESTUDENT.Sno=SC.SnoANDCOURSE.Cno=SC.Cno
(9)求选修数学课且成绩为90分以上的学生学号、姓名、及成绩。
SELECTSTUDENT.Sno,Sname,Grade,Cname
FROMSTUDENT,SC,COURSE
WHERESTUDENT.Sno=SC.SnoANDCOURSE.Cno=SC.CnoANDSC.Grade>=90
ANDCOURSE.Cname='数学';
(10)查询每一门课的间接先行课(即先行课的先行课)。
SELECTt1.Cno,t1.Cname,t3.Cno,t3.Cname
fromCOURSEt1,COURSEt2,COURSEt3
WHEREt1.Cpno=t2.Cnoandt2.Cpno=t3.Cno
2.在供应系统GYXT数据库中进行如下操作:
(1)求供应工程J1零件的供应商号SNO。
USEGYXT
SELECTDISTINCTSNO
FROMSPJ
WHEREJNO='J1';
(2)求供应工程J1零件P1的供应商号SNO。
USEGYXT
SELECTDISTINCTSNO
FROMSPJ
WHEREJNO='J1'ANDPNO='P1';
(3)统计每种零件的供应总量。
USEGYXT
SELECTSPJ.PNO,PNAME,COUNT(*)
FROMSPJ,P
WHERESPJ.PNO=P.PNO
GROUPBYSPJ.PNO,PNAME;
时间:
机房号:
得分:
实验3嵌套查询和集合查询
实验目的:
1.熟练掌握SQLServer查询分析器的使用方法,加深对标准SQL查询语句的理解。
2.熟练掌握数据查询中的嵌套、分组、统计、计算和组合的操作方法。
实验内容:
1.基于实验一创建的教学管理JXGL数据库,实现数据的高级查询操作。
2.基于实验一创建的供应系统GYXT数据库,实现数据的基本查询操作。
实验步骤:
写出下列操作的SQL语句。
1.在教学管理JXGL数据库中进行如下操作:
(1)求选修了数学的学生的学号和姓名。
SELECTSTUDENT.Sno,Sname
FROMSTUDENT,SC
WHERESTUDENT.Sno=SC.SnoANDCno=2;
(2)求数学课程成绩高于李勇的学生学号和成绩。
SELECTSname,STUDENT.Sno
fromSC,STUDENT
WHEREGrade>
(SELECTGradefromSC
WHERESno=95001andCno=2)andCno=2andSTUDENT.Sno=SC.Sno;
(3)求其他系中年龄小于计算机系年龄最大者的学生。
SELECTSname,STUDENT.SnofromSTUDENT
WHERESage<(SELECTMAX(Sage)fromSTUDENT
WHERESdept='IS')andnotSdeptin('IS');
(4)求其他系中比计算机系学生年龄都小的学生。
SELECTSname,STUDENT.Sno
fromSTUDENTWHERESage<
(SELECTMIN(Sage)fromSTUDENT
WHERESdept='IS')andnotSdeptin('IS');
(5)求选修了数学课的学生姓名。
SELECTSnamefromSTUDENTWHERESnoin
(SELECTSnofromSCWHERECno=2);
(6)求没有选修数学课的学生姓名。
SELECTSname
fromSTUDENTWHERESnonotin
(SELECTSnofromSCWHERECno=2);
(7)查询选修了全部课程的学生的姓名。
SELECTSname
FROMSTUDENT
WHERESnoIN
(SELECTSnoFROMSC
GROUPBYSno
HAVINGCOUNT(Sno)=(SELECTCOUNT(Cno)FROMCOURSE));
(8)求至少选修了学号为“95002”的学生所选修的全部课程的学生学号和姓名。
SELECTSno,SnameFROMSTUDENT
WHERESnoIN(SELECTDISTINCTSnoFROMSCSCXWHERENOTEXISTS
(SELECT*FROMSCSCYWHERESCY.Sno=95002ANDNOTEXISTS
(SELECT*FROMSCSCZWHERESCZ.Sno=SCX.SnoANDSCZ.Cno=SCY.Cno)));/*XX的,不怎么理解*/
(9)求选修各门课的人数及平均成绩。
SELECTcount(*)astotal,avg(Grade)asavg_gradeFROMSC
groupbyCno
(10)求选修课程在2门以上且都及格的学生号及总平均分。
SELECTSno,avg(Grade)asavg_gradeFROMSC
groupbySnoHAVINGCOUNT(Sno)>=2andmin(grade)>60;
(11)求95级学生中选修课程在2门以上且都及格的学生号及总平均分,并按平均成绩排序。
SELECTSno,avg(Grade)asavg_gradeFROMSC
groupbySnoHAVINGCOUNT(Sno)>=2andmin(grade)>60
ORDERBYavg(Grade)DESC;
(12)统计每个人及格的成绩的平均值,及格的门数,结果按平均成绩降序,及格门数降序排列。
SELECTSno,avg(Grade)asavg_gradeFROMSC
groupbySnoHAVINGCOUNT(Sno)>=2andmin(Grade)>=60
ORDERBYavg(Grade)DESC;
13)统计所有课程均及格学生的平均成绩,及格的门数,结果按平均成绩降序,及格门数降序排列。
SELECTSno,COUNT(*)ASCno_Num,AVG(Grade)ASAveScore
FROMSC
GROUP
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 原理 应用 实验