首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
(1)用SQL语句查询至少有三门的课程成绩在70分以上(包括70分)的学生姓名,并将结果按升序存入表文件results.dbf,然后将该SQL语句粘贴在SQL TXT。文件的第二行(只占一行)。 (2)modi.prg程序的功能是:先为“学生”表增
(1)用SQL语句查询至少有三门的课程成绩在70分以上(包括70分)的学生姓名,并将结果按升序存入表文件results.dbf,然后将该SQL语句粘贴在SQL TXT。文件的第二行(只占一行)。 (2)modi.prg程序的功能是:先为“学生”表增
admin
2015-08-20
54
问题
(1)用SQL语句查询至少有三门的课程成绩在70分以上(包括70分)的学生姓名,并将结果按升序存入表文件results.dbf,然后将该SQL语句粘贴在SQL TXT。文件的第二行(只占一行)。
(2)modi.prg程序的功能是:先为“学生”表增加一个“平均成绩”字段,数据类型为N(6,2);然后根据“选课”表统计每个学生的平均成绩,并写入新添加的字段。
该程序有三处错误,请改正,使程序能正确运行(在指定处修改,不允许增加或删除程序行)。
选项
答案
(1) ①在命令窗口输入如下SQL查询代码(以下SQL查询语句是通过查询设计器生成): 1 SELECT 学生.姓名; 2 FROM 成绩管理!学生INNER JOIN成绩管理!选课; 3 ON学生.学号=选课.学号; 4 WHERE选课.成绩>=70; 5 ORDER BY学生.姓名; 6 GROUP BY学生.学号; 7 HAVING COUNT(选课.课程号)>=3; 8 INTO TABLE results.dbf ②在命令窗口执行命令:MODIFY FILE SQL,打开文本文件编辑器。将命令窗口的查询语句复制到SQL文本文件中。 (2) 步骤1:在命令窗口执行命令:MODIFY COMMAND modi,打开程序文件,文件中的命令代码如下: l CLOSE ALL 2 OPEN DATABASE 成绩管理 3 USE选课IN 0 4 USE学生EXCl,IN 0 5 ***********Error*********** MODIFY TABLE学生ADD平均成绩N(6,2) 6 SELECT学生 7 ***********Error*********** DO WHILE EOF() 8 SELECT AVG(成绩)FROM选课WHERE 学号=学生.学号INTO ARRAY cj 9 ***********Error*********** REPLACE平均成绩=cj[1] 10 cj[1]=0 11 SKIP 12 ENDDO 13 CLOSE DATABASE 修改程序中的错误行,修改后的程序如下: CLOSE ALL OPEN DATABASE成绩管理 USE选课IN 0 USE学生EXCL IN 0 ALTER_TABLE学生ADD平均成绩N(6,2) SELECT 学生 DO WHILE NOT EOF() SELECT AVG(成绩) FROM选课 WHERE学号=学生.学号INTO.ARRAY cj REPLACE平均成绩WITH cj【1】 cj[1]=0 SKIP ENDDO CLOSE DATABASE 步骤2:保存文件修改,在命令窗口执行命令:
DO MODI
,执行程序文件。
解析
(1)本题主要考查的是SQL分组计算的查询。根据题目要求,SQL语句主要设计思路如下:
首先对“学生”和“选课”表进行联接,联接条件为两个表中“学号”相同的记录;接着筛选表中成绩大于70的所有记录(通过WHERE短语指出),对筛选后的记录按“学号”字段分组(通过GROUP BY短语分组),然后通过HAVING语句进一步限定分组条件,要求统计每组学号中“课程号”记录总数大于等于3,这样便可得出至少有三门课程成绩在70分以上的学生记录;查询结果最终保存在results表中,输出字段只包括学生的“姓名”字段。
(2)本题主要考查了SQL定义功能;SQL简单计算查询;DO WHILE循环;visual FoxPro修改记录命令。题目所提供的源程序功能大致如下:
首先打开“成绩管理”数据库,并打开库中的数据表“选课”和“学生”;接着利用SQL定义功能修改表结构;然后利用DO WHILE循环,依次计算“选课”表中每个学生的平均成绩,计算条件为“选课”表中的“学号”字段值等于“学生”表中当前记录的“学号”字段值,并将平均成绩保存到数组中;最后利用visual FoxPro修改记录命令REPLACE将数组中的值赋给“学生”表的“平均成绩”字段。
本题第一处错误是表结构修改语句的错误,为表增加字段的关键字是ADD而不是AITER,ALTER只能用来修改已存在的字段;第二处错误是DO WHILE循环格式错误,缺少WHILE短语;第三处错误是修改记录命令格式错误,指定修改值的短语为WITH而不是SET。
转载请注明原文地址:https://kaotiyun.com/show/pXEp777K
本试题收录于:
二级VF题库NCRE全国计算机二级分类
0
二级VF
NCRE全国计算机二级
相关试题推荐
要撤销SQL模式ST_CO及其下属所有的元素,可用______语句来实现。
在生成参照完整性中,设置更新操作规则时选择了“限制”选项卡后,则______。
关系数据库中,实现表与表之间的联系是通过______。
按照逻辑结构分类,结构可以分为线性结构和非线性结构,栈属于______。
在以下关于索引的说明中,错误的是______。
VisualFoxPro6.0的系统配置文件是______。
对数据元素序列(49,72,68,13,38,50,97,27)进行排序,前三趟排序结束时的结果如下:第一趟为13,72,68,49,50,97,27;第二趟为13,27,68,49,38,50,97,72;第三趟为13,27,38,49,68,50,97
设有图书管理数据库:图书(总编号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))借阅(借书证号C(4),总编
删除学生表的候选索引XUESHINDEX的SQL语句为:ALTERTABLE学生表______TAGXUESHINDEX
使用SELECT-SQL命令建立查询时,若要将查询结果输出到一临时数据表中,需要选择使用以下______子句。
随机试题
采用正注方法的分层注水井,其注水压力除了受油管摩擦阻力的影响外,还受水嘴阻力的影响,因此各层的注水压差是()的。
患者,男性,70岁。风湿性关节炎,红外线照射20分钟,照射中患者局部皮肤出现桃红色均匀红斑,说明
在其他基础数据不变的情况下,某建设项目拟采用甲、乙两套价格进行财务分析。价格乙的原料与产品的价格均高于价格甲,但其产品高出原料的差价要远低于取值较低的价格甲的差价。关于该项目财务分析指标的说法,正确的有()。
下列选项中,不属于《建设工程监理规范》(GB50319—2000)作出解释的建设工程监理常用术语名词的是( )。
钢梁制造使用的钢材表面有锈蚀、麻点或划痕等缺陷时,其深度不得大于该钢材厚度允许负偏差值的()。
施工总承包序列企业资质设有()。
下列业务中属于传统的中间业务的是()
Whatisthepurposeofthewoman’stalk?
Itwasrecommendedthatpassengers______smokeduringtheflight.
Yearsago,doctorsoftensaidthatpainwasanormalpartoflife.Inparticular,whenolderpatients【C1】______ofpain,theywer
最新回复
(
0
)