首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
(1)student是一个“学生”表,其中包含学号(C8)、姓名(C 8)、性别(C 2)、政治面目(C 4)、班级(C 5)等字段。考生文件夹下的modil.prg程序文件的功能是显示输出所有政治面目为“群众”的“男”生的姓名和班级,每行输出一个学生的信
(1)student是一个“学生”表,其中包含学号(C8)、姓名(C 8)、性别(C 2)、政治面目(C 4)、班级(C 5)等字段。考生文件夹下的modil.prg程序文件的功能是显示输出所有政治面目为“群众”的“男”生的姓名和班级,每行输出一个学生的信
admin
2015-08-20
39
问题
(1)student是一个“学生”表,其中包含学号(C8)、姓名(C 8)、性别(C 2)、政治面目(C 4)、班级(C 5)等字段。考生文件夹下的modil.prg程序文件的功能是显示输出所有政治面目为“群众”的“男”生的姓名和班级,每行输出一个学生的信息;程序中有三处错误,请加以改正。
说明:程序中******ERROR FOUND******的下一行即为错误所在行。请用改正后的程序行覆盖错误所在行,不要插入或删除任何程序行。
(2)建立命令文件sprog.prg,该命令文件包含如下两条语句:
. 第一条语句使用SQL UPDATE命令计算和更新student表的年龄字段值(计算年龄的表达式是year(dat())-year(出生日期))。
. 第二条语句使用SQLSELECT命令查询各种“政治面目”的学生人数和平均年龄,并将结果存储于表sqlresults(字段名是政治面目、人数和平均年龄)。
说明:以上命令文件必须执行,并产生所要求的结果。
选项
答案
(1) 步骤1:在命令窗口执行命令:MODIFY COMMAND modil,打开程序文件,文件中的命令代码如下: 1 SET TALK OFF 2 USE student 3 LOCATE FOR政治面目="群众" 4 "************error************ DO WHILE.NOT.FOUND() 5 IF性别="男" 6 CONTINUE 7 ************error*********** BREAK 8 ENDIF 9 7姓名,班级 10 ************error************ SKIP 11 ENDDO 12 USE 13 SET TALK ON > 修改程序中的错误行,修改后的程序如下: 1 SET TALK OFF 2 USE student &&打开student表 3 LOCATE FOR政治面目="群众" &&查找当前记录的“政治面目”为“群众” 4 DO WHILE FOUND() &&循环条件为找到"政治而目"为"群众"的记录时进入循环 5 IF性别="男" &&如果性别为“女”,继续执行下面的语句,否则执行ENDIF语句之后的语句 6 CONTINUE &&返回到循环体起始位置继续重新判断下一条记录“政治面目”值是否为“群众” 7 LOOP &&返旧到循环体起始位置,即 DO WHILE处重新判断,不再执行后面的语句 8 ENDIF &&当IF处条件不成立时,直接执行该语句后面的命令 9 ?姓名,班级&&当前面的IF条件语句不成立时,执行该语句,显示当前记录的“姓名”和“班级”值 10 CONTINUE &&返回到循环体起始位置继续重新判断下一条记录"政治面目"值是行为"群众" 11 ENDDO &&当DO WHILE处条件不成立时,直接退出循环体,执行该语句后面的命令 12 USE &&关闭当前打开的表 13 SET TALK ON 步骤2:保存文件修改,在命令窗口执行命令:DO modil.prg,执行程序文件。 (2) 步骤1:在命令窗口执行命令:
MODIFY COMMAND sprog
,打开程序文件编辑器。 步骤2:在程序文件编辑器中输入如下代码(相关SQL查询语句是通过查询设计器生成): 1 UPDATE student SET年龄=YEAR (DATE()) - YEAR(出生日期) 2 SELECT STUDENT.政治面目,COUNT (STUDENT.学号)AS人数,AVG(STUDENT.年龄)AS平均年龄; FROM student; 4 GROUP BY student.政治面目; 5 INTO TABLE sqlresults.dbf 步骤3:保存文件修改,在命令窗口执行命令:
DO sprog.prg
,执行程序文件。
解析
(1)本题主要考查的是利用Visual FoxPro命令查询定位数据表中的记录。此类型的题主要通过一个DO WHILE循环语句对表中的记录逐条比较,对满足条件的记录进行相关的操作。
本题中第一处错误是循环条件的错误,进入循环体的条件是逻辑值为真,第二处错误中属于命令短语错误,visual FoxPro中没有BREAK命令,第三处错误是SKIP命令错误,该命令虽然可以将当前记录指针指向下一条记录,但不再执行LOCATE FOR处的条件判断,如果要包含判断功能,则要使用CONTINUE短语。本题程段中各语句的功能可参考“操作步骤”中对各条语句的注释说明,这里不再细说。
(2)本题考查了SQL数据更新功能和分组计算查询功能。本题数据更新语句可直接套用SQL更新语句的命令格式;对数据进行分组计算查询时,用来计数的函数为COUNT(),用来求平均值的函数为AVG(),通过AS短语可以指定新的字段名,另外,对记录进行分组时,分组字段要设置正确,根据题意,本题的分组字段应为“学生”表中的“政治面目”字段。
转载请注明原文地址:https://kaotiyun.com/show/1PEp777K
本试题收录于:
二级VF题库NCRE全国计算机二级分类
0
二级VF
NCRE全国计算机二级
相关试题推荐
在SQL的数据定义功能中,删除表字段名的命令格式是()。
假设订货管理数据库中有3个表,仓库.DBF、职工.DBF和订购单.DBF,它们的结构分别如下:仓库表(仓库号C(4),城市C(10),面积I(4))职工表(仓库号C(4),职工号C(4),工资Y)订购单表(职工号C(4),供应商号C
如果在一个运算表达式中包含有逻辑运算、关系运算和算术运算,并且其中未用圆括号规定这些运算的先后顺序,那么这样的综合型表达式的运算顺序是______。
在表设计器的"字段"选项卡中有一组定义字段有效性规则的项目,它们是【】、"信息"和"默认值"。
有如下SQL语句:SELECT出版单位,MIN(价格)FROM图书GROUPBY出版单位查询结果中,第一条记录的值是
用于指明表格数据源类型的属性是
查询订购单号首字符是"P"的订单信息,应该使用命令
有一学生表文件,且通过表设计器已经为该表建立了若干普通索引。其中一个索引的索引表达式为姓名字段,索引名为XM。现假设学生表已经打开,且处于当前工作区中,那么可以将上述索引设置为当前索引的命令是
扩展名为mnx的文件是
表文件和索引文件都已打开,为确保记录指针定位在第一条记录上,可使用命令
随机试题
党的十八届三中全会指出,全面深化改革的总目标是【】
A、格列本脲B、普通胰岛素C、阿卡波糖D、二甲双胍E、罗格列酮属于磺酰脲口服降血糖药的是
既能泻火除烦,又能凉血止血的药物是既能清热泻火,又能退虚热的药物是
在进行人工饮水加氟时适宜的氟浓度一般应保持在
女,50岁。2周前无明显诱因出现中上腹隐痛,皮肤巩膜黄染,小便呈浓茶样,1周前腹痛缓解,皮肤黄染减退,无皮肤瘙痒。实验室检查:ALT90U/L,尿胆红素(+),该患者最可能的疾病与胰头癌的鉴别诊断要点是
阿片类药物中毒的首选拮抗剂为
对各类结构进行多遇地震作用下的抗震变形验算时,下列各类结构的最大的弹性层间位移限值中正确的是()。
防烟分区的长边一般不大于()m。
Forcenturies,explorershaveriskedtheirlivesventuringintotheunknownforreasonsthatweretovaryingdegreeseconomican
McDonald’s,theburgerbehemothannounceda5.2%dropinprofitsforthefirstthreemonthsof2014anda1.7%decreaseinsame
最新回复
(
0
)