首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
在考生文件夹下,打开商品销售数据库cdb,完成如下简单应用: (1)使用一对多报表向导建立名称为p order的报表。要求从父表顾客表cust中选择所有字段,从子表订单表order中选择所有字段;两表之间采用“顾客号”字段连接;按“顾客号”字段升序排序;报
在考生文件夹下,打开商品销售数据库cdb,完成如下简单应用: (1)使用一对多报表向导建立名称为p order的报表。要求从父表顾客表cust中选择所有字段,从子表订单表order中选择所有字段;两表之间采用“顾客号”字段连接;按“顾客号”字段升序排序;报
admin
2014-11-30
23
问题
在考生文件夹下,打开商品销售数据库cdb,完成如下简单应用:
(1)使用一对多报表向导建立名称为p order的报表。要求从父表顾客表cust中选择所有字段,从子表订单表order中选择所有字段;两表之间采用“顾客号”字段连接;按“顾客号”字段升序排序;报表样式为“经营式”,方向为“纵向”;报表标题为“顾客订单表”。然后修改该报表,在页注脚中增加一个标签“制表人:新思路”;该标签水平居中,标签中的“:”为中文的冒号。
(2)修改一个名称为TWO.PRG的命令文件。该命令文件统计每个顾客购买商品的金额合计(应付款),结果存储在临时表1s中。然后用Is中的每个顾客的数据去修改表scust对应的记录。该命令文件有3行语句有错误,打开该命令文件进行修改。
注意:直接在错误处修改,不可改变SQL语句的结构和短语的顺序,不允许增加、删除或合并行。修改完成后,运行该命令文件。
选项
答案
(1)步骤1:在命令窗口执行命令:
OPEN DATABASE cdb
,打开cdb数据库。 步骤2:执行【文件】→【新建】菜单命令,或单击“常用”工具栏的“新建”按钮,在弹出的“新建”对话框中选中“报表”选项,然后单击“向导”图标按钮,系统弹出“向导选取”对话框,选中“一对多报表向导”项,单击“确定”按钮,启动报表向导。 步骤3:在报表向导的“步骤1-从父表选择字段”界面的“数据库和表”下选中cust表,将“可用字段”中的字段全部添加到“选定字段”中,单击“下一步”按钮。 步骤4:在报表向导的“步骤2-从子表选择字段”界面的“数据库和表”下选中order表,将“可用字段”中的字段全部添加到“选定字段”中,单击“下一步”按钮。 步骤5:在报表向导的“步骤3-为表建立关系”界面中系统自动建立两个表的联系,单击“下一步”按钮。 步骤6:在报表向导的“步骤4.排序记录”界面中双击“可用的字段或索引标识”中的“顾客号”字段到“选定字段”列表中,再选择“升序”,单击“下一步”按钮。 步骤7:在报表向导的“步骤5-选择报表样式”界面的“样式”下选中“经营式”,方向为“纵向”,单击“下一步”按钮。 步骤8:在报表向导的“步骤6-完成”界面中的“报表标题”下方文本框中输入“顾客订单表”,单击“完成”桉钮。 步骤9:在“另存为”对话框的“保存报表为:”框中输入表单文件名p_order,单击“保存”按钮。 步骤10:在命令窗口输入命令:MODIFY REPORT p_order,打开报表设计器修改报表。向报表设计器最底端的“页注脚”带区添加一个标签控件,并输入“制表人:新思路”,然后选中标签,在“布局”工具栏中单击“水平居中”命令按钮(工具栏中的倒数第4个按钮),设置标签为水平居中。 (2)步骤1:在命令窗口执行命令:MODIFY COMMAND two,打开程序文件,文件中的命令代码如下: 1 CLOSE DBF 2 PRIVATE no,money 3 USE scust 4 *下面的一行语句有错误 5 SELECT顾客号,数量*单价应付款; 6 FROM order JOIN comm ON order.商品号=comm.商品号; 7 GROUP BY顾客号; 8 INTO cURSOR ls 9 SELECT scust 10 *下面的一行语句有错误 11 DO WHILE EOF() 12 no=顾客号 13 SELECT ls 14 LOCAT FOR顾客号=no 15 monev=应付款 16 SELECT scust 17 *下面的一行语句有错误 18 REPLACE ALL应付款=monev 19 sKIP+1 20 ENDDO 21 CLOSE TABLE 22 RETURN 修改程序中的错误行,修改后的程序如下: 1 CLOSE DBF 2 PRIVATE no,money 3 UE scust 4 *下面的一行语句有错误 5 SELECT顾客号,sum(数量*单价)应付款; 6 FROM order JOIN comm ON order.商品号=comm.商品号; 7 GROuP BY顾客号; 8 INTO CURSOR ls 9 SELECT scust 10 *下面的一行语句有错误 11 DO WHILE!EOF() 12 no=顾客号 13 SELECT ls 14 LOCAT FOR顾客号=no 15 monev=应付款 16 SELECZ、scust 17 *下面的一行语句有错误 18 REPLACE应付款with monev 19 SKIP+1 20 ENDDO 21 CLOSE TABLE 22 RETURN 步骤2:保存文件修改,在命令窗口执行命令:DO two,执行程序文件。
解析
(1)本题考查报表向导以及报表设计器的使用,在报表设计器中添加文字,可以通过“报表控件”工具栏中的“标签”控件进行添加。
(2)本题考查了DO WHLE循环语句;SQL简单的计算查询;visual FoxPro修改表记录语句,程序的功能大致如下:
首先定义两个私有变量,然后通过SQL语句计算每个顾客购买商品的金额合计,将结果保存到一个临时表中;接着通过一个DO循环语句逐条判断scust表中的记录,修改scust表中顾客号与临时表ls表中顾客号对应相等的“应付款”字段值。
根据对程序语句的分析,可以得知:
第一处错误是SQL计算语句错误,要求应付款应该是合计值,输出字段中还缺少sum()函数进行合计。
第二处错误是DO循环条件错误,循环条件应该是没有到记录末尾,因此应使用!eof()。
第三处错误是修改记录的命令错误,应该使用replace…with…命令。
转载请注明原文地址:https://kaotiyun.com/show/9sEp777K
本试题收录于:
二级VF题库NCRE全国计算机二级分类
0
二级VF
NCRE全国计算机二级
相关试题推荐
设有如下说明,请回答小题:有3个数据库表:金牌榜.DBF国家代码C(3),金牌数I,银牌数I,铜牌数I获奖牌情况.DBF国家代码C(3),运动员名称C(20),项目名称C(30),名次I国家.DBF国家代码C(3),国家名称
基于下述描述:设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2))读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20))借阅(借书证
下面所列条目中,错误的SQL语句是______。
在标准SQL中,建立视图的命令是______。
下面关于运行应用程序的说法正确的是______。
自由表与数据库表相比较,在数据库中可以建立______索引,而在自由表中不能建立。
查询订单数在3个以上、订单的平均金额200元以上的职员号。正确的SQL语句是( )。
将SQL的查询结果如果要追加到文本文件的尾部,应使用______短语加以说明。
利用SQL派生一个包含“课程名称”、“姓名”和“成绩”的视图,要求按“课程名称”升序排序,正确的命令是()。
随机试题
中药鸡内金在鸡哪个器官()。
“古方九种心痛……详其所由,皆在胃脘,而实不在于心也。”此语出自
乐园社区有一些外来务工人员,主要从事社区服务业,社会工作者设计了小组活动,将他们与社区中的其他居民组织在一起帮助他们建立联系。这种社区工作方法主要侧重于()。[2010年真题]
培训效果的正式评估的优点不包括()。
下列属于负强化事例的是()。
全国性抗日战争爆发的标志是()。
坐在餐桌前,举筷享用食物,我们早已司空见惯,却浑然不知盘中美餐在全球范围内________的利害关系。现代社会高度分工,我们远离春耕秋收,只有食品价格飙升的时候,粮食生产才会引起我们关注。去年,粮价一路攀升,为我们的长期________敲响了警钟。填入画横
《赋役黄册》
试论物权与债权的区别。
3岁前儿童手的动作发展中,下列动作发展最晚的是()。
最新回复
(
0
)