1、国家二级 VF机试(操作题)模拟试卷 94及答案与解析 一、基本操作题 1 (1)新建一个数据库 mydatabase,在库中建立数据库表 temp,表内容和结构与当前文件夹下的 “歌手信息 “表完全相同。 (2)建立快捷菜单 mymenu,快捷菜单有两条命令: “打开文件 “和 “关闭文件 “。 (3)使用报表向导建立一个报表,报表的数据来源分别是 “打分表 “(父表)和 “歌手信息 “(子表)两个数据库文件,选取这两个表的全部字段,连接字段为 “歌曲编号“,按 “分数 “升序排列,报表的标题为 “打分一览表 “,最后将报表保存为 “打分表 “。 (4)使用 SQL命令将表 temp中歌手编
2、号为 111的歌手的年龄修改为 20岁,命令存储在 mypro.prg中。 二、简单应用题 2 在考生文件夹下完成下列操作: (1)修改程序 proone.prg中带有注释的四条语句(修改或填充,不要修改其他的语句),使之能够正常运行,程序的功能是将大于等于 11并且小于等于 2011的素数存储于表 prime中。修改完成后请运行该程序。 (2)编写 SQL命令查询歌手平均分大于 8.2的歌手的姓名、歌手编号和平均分,查询结果存储于 result.dbf中(字段名依次为姓名、 歌手编号和平均分),结果按歌手的平均分降序排列。 SQL命令要保存在 ttt.prg文件中。 三、综合应用题 3 在考
3、生文件夹下完成下列操作: (1) 打开数据库文件 mydatabase,为表 temp建立主索引:索引名和索引表达式均为 “歌手编号 “。 (2)利用表 temp建立一个视图myview,视图中的数据满足以下条件:年龄大于等于 28岁并且按年龄升序排列。(3)建立一个名为 staff的新类,新类的父类是 CheckBox,新类存储于名为myclasslib的类库中。 (4)数据库 “比赛情况 “中有 3个数据库表:打分 表、歌手信息和选送单位。建立包括 4个标签、一个列表框( List1)和 3个文本框的表单myform,其中 Label1、 Label2、 Label3、 Label4的标题
4、依次为选送单位、最高分、最低分和平均分;文本框 Text1、 Text2、 Text3依次用于显示最高分、最低分和平均分,如下图所示。 (5) 列表框( List1)的 RowSource和 RowSourceType属性手工指定为 “选送单位 .单位名称 “和6。 (6)为列表框( List1)的 DblClick事件编写程序。程序的功能是:表单运行时,用户双击列表框 中选项时,将该选送单位的 “单位名称 “、 “最高分 “、 “最低分 “和 “平均分 “四个字段的信息存入自由表 two.dbf中(字段名依次为单位名称、最高分、最低分和平均分),同时将统计数据显示在界面相应的文本框中。 (7
5、)最后运行表单,并在列表框中双击 “空政文工团 “。 国家二级 VF机试(操作题)模拟试卷 94答案与解析 一、基本操作题 1 【正确答案】 【操作步骤】 (1)通过 “新建 “对话框新建一个数据库文件mydatabase,在打开的数据库空白处单击鼠标右键,选择 “新建表 “命令,输入表名“temp“, 在打开的表设 计器中设计表结构如下: 单击 “确定 “按钮,在弹出的对话框中选择 “否 “,即不立即输入数据。 (2)通过 “新建对话框 “新建一个菜单,并在弹出的对话框中选择 “快捷菜单 “。分别输入两个菜单名称 “打开文件 “和 “关闭文件 “,保存菜单并命名为 “mymenu“。然后单击
6、菜单栏 “菜单 “-“生成 “命令,生成可执行文件。 (3)步骤 1:通过 “新建 “对话框新建一个报表,利用向导创建报表。步骤 2:在 “向导选取 “对话框中,选择 “一对多报表向导 “并单击 “确定 “按钮,并显示 “一对多报表向导 “对话框。步骤 3:在步骤 1从父表选择字段中,在 “数 据库和表 “列表框中,选择表 “打分表 “,接着在 “可用字段 “列表框中显示打分表的所有字段名,将所有字段添加至 “选定字段 “列表框中,单击 “下一步 “按钮。步骤 4:在步骤 2从子表选择字段中,在 “数据库和表 “列表框中,选择表 “歌手信息 “,接着在 “可用字段 “列表框中显示表歌手信息的所
7、有字段名,添加所有字段至 “选定字段 “列表框中,单击 “下一步 “按钮。步骤 5:在步骤 3为表建立关系中,单击 “下一步 “按钮。步骤 6:在步骤 4排序记录中,选择 “分数 “以及选择 “降序 “单选按钮,再单击 “添加 “按钮,单击 “下一步 “按钮。步骤 7:在步 骤 5选择报表样式中,世界单击 “下一步 “按钮。步骤 8:在步骤 6完成中,输入报表标题 “打分一览表 “,单击 “完成 “。步骤 9:在 “另存为 “对话框中,输入报表名 “打分表 “,再单击 “保存 “按钮。 (4)在命令窗口输入命令 “update temp set 年龄 =20 where 歌手编号 =111 “
8、,然后按回车执行。新建一个程序文件 “mypro.prg“,将该语句复制到程序文件中,保存程序。 二、简单应用题 2 【正确答案】 【操作步骤】 (1)单击常用工具栏 “打开 “按钮,打开考生文件夹下的程序文件 “proone.prg“,修改如下: 第一处错误: create prime(dat f) 修改为: create table prime(dat f) 第二处填入: loop 第三处填入: exit 第四处错误: insert prime values(n) 修改为: insert into prime values(n) 保存对程序的修改然后运行。 (2)步骤 1:在命令窗口输入命
9、令如下,然后按回车执行: SELECT 歌手信息 .姓名 , 歌手信息 .歌手编号 , avg(分数 ) as 平均分 ; FROM 打分表 INNER JOIN 歌手信息 ; ON 打分表 .歌手编号 = 歌手信息 .歌手编号 ; GROUP BY 歌手信息 .歌手编号 having 平均分 8.2; ORDER BY 平均分 DESC; INTO DBF result 步骤 2:新建一个程序文件 “ttt.prg“,将该语句复制到程序文件中,保存程序。 三、综合应用题 3 【正确答案】 【操作步骤】 (1)单击常用工具栏 “打开 “按钮,打 开考生文件夹下的数据库 “mydatabase“
10、。右键单击学生表 “temp“,选择 “修改 “命令。在打开的表设计器中,单击 “索引 “选项卡,输入索引名 “歌手编号 “,类型设为 “主索引 “,索引表达式为 “歌手编号 “。单击 “确定 “按钮保存对表的修改。 (2)在数据库 “mydatabase“中,右键单击数据库空白处,选择 “新建本地视图 “命令,将 “temp“表添加到新建的视图中。 步骤 2:在字段选项卡中,将所有字段添加到选定字段中。 步骤 3:在 “筛选 “选项卡中,设置条件 “temp.年龄 28“. 步骤 4:在 “排序依据 “选项卡 中,设置按 “年龄 “升序排列。 步骤 5:保存视图并命名为 myview。 (3
11、)步骤 1:通过 “新建 “对话框新建一个 “类 “文件。 步骤 2:在弹出的 “新建类 “对话框中,输入 “类名 “staff,在 “派生于 “下拉列表中选择CheckBox,单击 “存储于 “文本框后的按钮,在打开的 “另存为 “对话框选择考生文件夹,输入文件名 myclasslib,单击 “确定 “按钮。 (4)步骤 1:单击菜单栏 “文件 “-“新建 “命令或单击常用工具栏 “新建 “按钮新建表单。 步骤 2:在打开的表单设计器中 ,根据题目要求,通过表单控件工具栏添加 4个标签、 一个列表框、 3个文本框。将 4个标签控件的 caption属性分别修改为 “选送单位 “、 “最高分
12、“、 “最低分 “和 “平均分 “。适当调整各控件的大小和布局。 (5)右键单击表单空白处,选择 “数据环境 “命令,将 “歌手信息 “、 “选送单位 “和 “打分表 “三个表添加到数据环境中。然后选中列表框控件,将其 RowSource属性设为 “选送单位 .单位名称 “, RowSource Type属性设为 “6“。 (6)双击列表框控件,编写其 Dbclick事件代码如下: danweimingcheng=thisform.List1.Value SELECT 单位名称 ,max(分数 ) as 最高分 ,min(分数 ) as 最低分 ,avg(分数 ) 平均分 ; FROM 比赛情
13、况 !打分表 INNER JOIN 比赛情况 !歌手信息 ; INNER JOIN 比赛情况 !选送单位 ; ON 歌手信息 .选送单位号 = 选送单位 .单位号 ; ON 打分表 .歌手编号 = 歌手信息 .歌手编号 ; GROUP BY 选送单位 .单位号 where 单位名称 = danweimingcheng into dbf two select 最高分 from two into array a thisform.text1.value=a select 最低分 from two into array b thisform.text2.value=b select 平均分 from two into array c thisform.text3.value=c 7.保存表单为 myform,并运行。在列表框中双击 “空政文工团 “,查看结果。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1