第五十三套
一、基本操作题(共4小题,第1和2题是7分、第3和4题是8分)
在考生文件夹下,完成如下操作:
1. 从student表查询所有性别为"男"的学生信息,并按学号升序排序将查询结果存入results表。
2. 利用表单向导生成一个表单,该表单含有student表的学号、班级、姓名和性别4个字段,按学号字段升序排序,其他设置采用默认值,并将表单保存为student.scx文件。
3. 建立一个命令文件myprog.prg,该命令文件只有一行语句,即执行前一小题生成的表单文件。
4. 在student表最后增加一个"年龄"字段,类型为数值型(2)。
本题的主要考核点:查询的应用、表单向导的使用、命令文件的建立、表结构的修改。
解题思路:
1.本题可使用SQL语句完成此查询,SQL语句代码如下:
SELECT * FROM student WHERE 性别 = "男" ORDER BY 学号 INTO TABLE results
2.启动表单向导可在"文件"菜单中选择"新建"或者单击工具栏上的"新建"按钮,打开"新建"对话框,文件类型选择表单,单击向导按钮。
3.可通过"文件"菜单中选择"新建"或者单击工具栏上的"新建"按钮,打开"新建"对话框来新建一个命令文件。执行表单的命令是:DO FORM 表单名
4.增加字段的方法:
打开表设计器,在原有字段之后插入一个新字段,在"新字段"格中输入新的字段名、字段类型及长度。
.
www.59wj.com
二、简单应用(2小题,每题20分,计40分)
1. 改错题
student是一个"学生"表,其中包含学号(C 8)、姓名(C 8)、性别(C 2)、政治面目(C 4)、班级(C 5)等字段。考生目录下的modi1.prg程序文件的功能是显示输出所有政治面目为"群众"的"男"生的姓名和班级,每行输出一个学生的信息;程序中有三处错误,请加以改正。
说明:程序中******ERROR FOUND******的下一行即为错误所在行。请用改正后的程序行覆盖错误所在行,不要插入或删除任何程序行。
2. 建立命令文件sprog.prg,该命令文件包含如下两条语句:
● 第一条语句使用SQL UPDATE命令计算和更新student表的年龄字段值(计算年龄的表达式是year(date()) - year(出生日期));
● 第二条语句使用SQL SELECT命令查询各种"政治面目"的学生人数和平均年龄,并将结果存储于表sqlresults(字段名是政治面目、人数和平均年龄)。
说明:以上命令文件必须执行,并产生所要求的结果。
第二处错误应改为:LOOP
第三处错误应改为:CONTINUE
2.根据题目先建立命令文件sprog.prg,可通过"文件"菜单中选择"新建"或者单击工具栏上的"新建"按钮,打开"新建"对话框来新建一个命令文件。再据题意写出SQL语句:
第一条为:UPDATE STUDENT SET 年龄=year(date()) - year(出生日期)
第二条为:SELECT Student.政治面目, COUNT(Student.学号) AS 人数,AVG(Student.年龄) AS 平均年龄 FROM student GROUP BY Student.政治面目 INTO TABLE sqlresults.dbf
三、综合应用(1小题,计30分)
考生文件夹下的gnht.dbf是一个合同管理表文件,其中部分字段的含义是:HTH(合同号)、DHDW(订货单位)、GHDW(供货单位)、JHSL(订货数量)。编写程序progzh.prg分别统计订货单位数、供货单位数、订货总数,并将结果填写到jieguo.dbf(在考生目录下已经存在)表文件中。说明:以上命令文件必须执行,并产生所要求的结果。
题的主要考核点:程序的建立与运行、SQL语句的使用等。
解题思路:
1.根据题目先建立命令文件progzh.prg,可通过"文件"菜单中选择"新建"或者单击工具栏上的"新建"按钮,打开"新建"对话框来新建一个命令文件。
2.本题程序可有多种写法,现列出SQL语句的一种方法:
select count(dist dhdw) as b from gnht into array a
update jieguo set num=a where name='订货单位数'
select count( dist ghdw) as b from gnht into array a
update jieguo set num=a where name='供货单位数'
select sum(jhsl) as b from gnht into array a
update jieguo set num=a where name='订货总数'
.