1、合工大数据库上机实验2数据库及应用课程实验报告实验名称: Visual FoxPro 6.0的基本操作 实验类型: 验证设计 实验学时: 8学时 学 号: 姓 名: 班 级: 指导教师: 罗贺 实验地点: 管理学院一号楼四楼机房 实验时间: 2012年11月19日、26日 二一二年十二月十日添加30条数据(3)求每门课的平均成绩,并把结果存入average表; 解:USE h:数据库实验作业二实验二score表.dbf EXCLUSIVE sele score表.Cno,avg(score表.score)as 平均分; from score表; into table average; grou
2、p by score表.Cno Browse 截图:(4)将学生“马丽鹃”的出生日期改为“1982.8.20”; 解:USE h:数据库实验作业二实验二student表.dbf EXCLUSIVE edit for sname=马丽娟 截图:(5)将所有学生的zipcode属性列值填补上; 解:repl Zipcode with 230006 repl all Zipcode with 230006 USE h:student.dbf EXCLUSIVE modify structure repl all Zipcode with 230006 截图:(6)将average表中的所有课程的平均
3、成绩置零; 解:USE h:数据库实验作业二实验二average.dbf EXCLUSIVE repl all 平均分 with 0 截图:(7)删除average表中的课程号为c007的平均成绩记录; 解:USE h:数据库实验作业二实验二average.dbf EXCLUSIVE delete for Cno=C007 browse pack Browse 截图:(8)删除所有average表中平均成绩记录; 解:delete all pack browse 截图:(9)建立一个临时学生信息表(tstudent),删除该表中的学号前六位为001011的所 有学生记录。 解:Select*;
4、 from student; into cursor tstudent; where substr(Sno,1,6)!=001011 browse 截图:(10)查询全体学生的学号与姓名; 解:Select Sno,Sname; From student 截图: (11)查询全体学生的学号、姓名、所属班级; 解:Select Sno,Sname,Sclass; From student 截图:(12)查询全体学生的详细记录; 解:Select *; From student 截图:(13)查询全体学生的姓名及其年龄; 解:Select Sname,year(date()-year(Sbirth
5、day) as age; From student 截图: (14)查询全体学生的姓名、出生年份; 解:Select Sname,Sbirthday; From student 截图:(15)查询所有修过课的学生的学号; 解:Select student.Sno; From score, student; Where score.Sno=student.Sno 截图: (16)查询“信管系0101”班全体学生名单; 解:Select Sname; From student; Where Sclass=信管系0101 截图: (17)查询查询所有年龄在27岁以下的学生姓名及其年龄; 解:Sele
6、ct Sname,year(date()-year(Sbirthday) as age; From student; Where year(date()-year(Sbirthday)=27 截图: (18)查询考试成绩有不及格的学生的学号; 解:Select Sno; From score; Where Score15 and year(date()-year(Sbirthday) 28 截图:(20)查询年龄不在15至28岁之间的学生姓名、班级和年龄; 解:Select Sname,Sclass, year(date()-year(Sbirthday) as age; From stude
7、nt; Where year(date()-year(Sbirthday)=28 截图:(21)查询“信管系0101”和“电商系0102”班的学生的姓名和班级信息; 解:Select Sname,Sclass; From student; Where Sclass=信管系0101or Sclass=电商系0102 截图:(22)查询既不是“信管系0101”也不是“电商系0102”班的学生的姓名和班级信息; 解:Select Sname,Sclass; From student; Where Sclass!= 信管系0101and Sclass!=电商系0102 截图: (23)查询学号为“01
8、1113104”的学生的详细情况; 解:Select *; From student; Where Sno=011113104 截图:(24)查询学号以“0111”打头的学生信息; 解:Select *; From student; Where substr(Sno,1,4)=0111 截图: (25)查询所有姓“张”学生的学号、姓名、性别、年龄; 解:Select Sno,Sname,year(date()-year(Sbirthday) as age; From student; Where Sname like 张% 截图:(26)查询名字中第二个字有“海”字的学生的学号、姓名、性别、年
9、龄; 解:Select Sno,Sname, year(date()-year(Sbirthday) as age; From student; Where substr(Sname,3,2)=海 截图:(27)查询所有不姓“刘”学生的姓名; 解:Select Sname; From student; Where substr(Sname,1,2)!=刘 截图:(28)查询课程号以“C”开头的最后两个字母为“05”的课程号和课程名; 解:Select Cno,Cname; From course; Where Cno like C%and substr(Cno,3,2)=05 截图:(29)某
10、些学生选修某门课程后没有参加考试,所以有选修课记录,但没有考试成绩,试查 找缺少考试成绩的学生和相应的课程号; 解:Select Sno,Cno; From score; Where Score=0 截图:(30)查找全部有成绩记录的学生学号、课程号; 解:Select Sno,Cno; From score; Where Score!=0 截图:(31)查找“电商系0101”班年龄在27岁以下的学生学号、姓名; 解:Select Sno,Sname; From student; Where Sclass=电商系0101and year(date()-year(Sbirthday)=2 截图:(40)自然连接student和score表; 解:Select *; From student full join score; On student.Sno=score.Sno 截图:(41)使用自身连接查询每一门课程的间接先行课(即先行课的先行课) 解:Select x.Cno,y.Cpno; From course as x,course as y; Where x.Cpno=y.Cno Group by x.Cno 截图:(42)使用复合条件连接查询选修“c001”号课程且成绩
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1