aaa 2006-4-3 17:14
2006二级vf笔试答案
<p>2006年4月计算机等级考试二级VF原卷及笔试答案</p><p>二级VF笔试答案 <附考题> 估计是标准的哦 想知道成绩的快来吧,定多有几个小错误 </p><p>4/2 VFP 考卷+答案 全国计算机等级考试二级笔试试卷<br/>Visual FoxPro数据库程序设计<br/>(考试时间90分钟,满分100分)<br/>一、选择题((1)~(35)每小题2分,共70分)<br/>下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。<br/>(1)数据的存储结构是指<br/>A) 存储在外存中的数据B) 数据所占的存储空间量<br/>C) 数据在计算机中的顺序存储方式D) 数据的逻辑结构在计算机中的表示<br/>(2)下列关于栈的描述中错误的是<br/>A)栈是先进后出的线性表B) 栈只能顺序存储<br/>C) 栈具有记忆作用D) 对栈的插入与删除*作中,不需要改变栈底指针<br/>(3)对于长度为n的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是<br/>A) 冒泡排序为n/2B) 冒泡排序为n<br/>C) 快速排序为nD) 快速排序为n(n-1)/2<br/>(4)对于长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为<br/>A) log2nB) n/2C) nD) n+1<br/>(5)下列对于线性链表的描述中正确的是<br/>A)存储空间不一定是连续,且各元素的存储顺序是任意的<br/>B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面<br/>C)存储空间必须连续,且前件元素一定存储在后件元素的前面<br/>D)存储空间必须连续,且各元素的存储顺序是任意的<br/>(6)下列对于软件测试的描述中正确的是<br/>A)软件测试的目的是证明程序是否正确<br/>B)软件测试的目的是使程序运行结果正确<br/>C)软件测试的目的是尽可能多地发现程序中的错误<br/>D)软件测试的目的是使程序符合结构化原则<br/>(7)为了使模块尽可能独立,要求<br/>A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强<br/>B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱<br/>C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱<br/>D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强<br/>(8)下列描述中正确的是<br/>A) 程序就是软件<br/>B) 软件开发不受计算机系统的限制<br/>C) 软件既是逻辑实体,又是物理实体<br/>D) 软件是程序、数据与相关文档的集合<br/>(9)数据独立性是数据库技术的重要特点之一。所谓数据独立性是指<br/>A) 数据与程序独立存放<br/>B) 不同的数据被存放在不同的文件中<br/>C) 不同的数据只能被对应的应用程序所使用<br/>D) 以上三种说法都不对<br/>(10) 用树形结构表示实体之间联系的模型是<br/>A) 关系模型B) 网状模型C) 层次模型D) 以上三个都是<br/>(11) 在创建数据库表结构时,为该表指定了主索引,这属于数据完整性中的<br/>A) 参照完整性B) 实体完整性C) 域完整性D) 用户定义完整性<br/>(12) 在创建数据库表结构时,为该表中一些字段建立普通索引,其目的是<br/>A) 改变表中记录的物理顺序B) 为了对表进行实体完整性约束<br/>C) 加快数据库表的更新速度D) 加快数据库表的查询速度<br/>(13) 数据库系统中对数据库进行管理的核心软件是<br/>A) DBMSB) DBC) OSD) DBS<br/>(14) 设有两个数据库表,父表和子表之间是一对多的联系,为控制子表和父表的关联,可以设置“参照完整性规则”,为此要求这两个表<br/>A)在父表连接字段上建立普通索引,在子表连接字段上建立主索引<br/>B)在父表连接字段上建立主索引,在子表连接字段上建立普通索引<br/>C)在父表连接字段上不需要建立任何索引,在子表连接字段上建立普通索引<br/>D)在父表和子表的连接字段上都要建立主索引<br/>(15) 关系运算中的选择运算是<br/>A)从关系中找出满足给定条件的元组的*作<br/>B)从关系中选择若干个属性组成新的关系的*作<br/>C)从关系中选择满足给定条件的属性的*作<br/>D)A和B都对<br/>(16) 在指定字段或表达式中不允许出现重复值的索引是<br/>A) 惟一索引B) 惟一索引和候选索引<br/>C) 惟一索引和主索引D) 主索引和候选索引<br/>(17) 在Visual FoxPro中,以下关于删除记录的描述,正确的是<br/>A)SQL的DELETE命令在删除数据库表中的记录之前,不需要用USE命令打开表<br/>B)SQL的DELETE命令和传统Visual FoxPro的DELETE命令在删除数据库表中的记录之前,都需要用USE命令打开表<br/>C)SQL的DELETE命令可以物理地删除数据库表中的记录,而传统Visual FoxPro的DELETE命令只能逻辑删除数据库表中的记录<br/>D)传统Visual FoxPro的DELETE命令在删除数据库表中的记录之前不需要用USE命令打开表<br/>(18) 在Visual FoxPro中,如果希望跳出SCAN……ENDSCAN循环体、执行ENDSCAN后面的语句,应使用<br/>A) LOOP语句B) EXIT语句C) BREAK语句D)RETURN语句<br/>(19) 打开数据库abc的正确命令是<br/>A)OPEN DATABASE abcB)USE abc<br/>C)USE DATABASE abcC)OPEN abc<br/>(20) 在Visual FoxPro中,下列关于表的叙述正确的是<br/>A)在数据库表和自由表中,都能给字段定义有效性规则和默认值<br/>B)在自由表中,能给字段定义有效性规则和默认值<br/>C)在数据库表中,能给字段定义有效性规则和默认值<br/>D)在数据库表和自由表中,都不能给字段定义有效性规则和默认值<br/>(21) Visual FoxPro的“参照完整性”中“插入规则”包括的选择是<br/>A) 级联和忽略B) 级联和删除C)级联和限制D) 限制和忽略<br/>(22) 在Visual FoxPro中,关于查询和视图的正确描述是<br/>A)查询是一个预先定义好的SQL SELECT语句文件<br/>B)视图是一个预先定义好的SQL SELECT语句文件<br/>C)查询和视图是同一种文件,只是名称不同<br/>D)查询和视图都是一个存储数据的表<br/>(23) 在Visual FoxPro中,以下关于视图描述中错误的是<br/>A) 通过视图可以对表进行查询B) 通过视图可以对表进行更新<br/>C)视图是一个虚表D) 视图就是一种查询<br/>(24) 使用SQL语句将学生表S中年龄(AGE)大于30岁的记录删除,正确的命令是<br/>A) DELETE FOR AGE>30B) DELETE FROM S WHERE AGE>30<br/>C) DELETE S FOR AGE>30D) DELETE S WHERE AGE>30<br/>(25) 在Visual FoxPro中,使用LOCATE FOR <expL>命令按条件查找记录,当查找到满足条件的第一条记录后,如果还需要查找下一条满足条件的记录,应使用<br/>A)再次使用LOCATE FOR <expL>命令<br/>B)SKIP命令<br/>C)CONTINUE命令<br/>D)GO命令<br/>(26) 在Visual FoxPro中,删除数据库表S的SQL命令是<br/>A) DROP TABLE SB) DELETE TABLE S<br/>C) DELETE TABLE S.DBFD) ERASE TABLE S<br/>(27) 下列表达式中,表达式返回结果为.F.的是<br/>A) AT(“A”,”BCD”)B) “[信息]”$“管理信息系统”<br/>C) ISNULL(.NULL.)D) SUBSTR(“计算机技术”,3,2)<br/>(28) 使用SQL语句向学生表S(SNO,SN,AGE,SEX)中添加一条新记录,字段学号(SNO)、姓名(SN)、性别(SEX)、年龄(AGE)的值分别为0401、王芳、女、18,正确的命令是<br/>A)APPEND INTO S (SNO,SN,SXE,AGE) valueS (‘0401’,’王芳’,’女’,18)<br/>B)APPEND S valueS (‘0401’,’王芳’,’女’,18)<br/>C)INSERT INTO S (SNO,SN,SEX,AGE) valueS (‘0401’,’王芳’,’女’,18)<br/>D)INSERT S valueS (‘0401’,’王芳’,18,’女’)<br/>(29) 假设某个表单中有一个命令按钮cmdClose,为了实现当用户单击此按钮时能够关闭该表单的功能,应在该按钮的Click事件中写入语句<br/>A) ThisForm.CloseB) ThisForm.Erase<br/>C) ThisForm.ReleaseD) ThisForm.Return<br/>(30) 在SQL的SELECT查询结果中,消除重复记录的方法是<br/>A) 通过指定主关系键B) 通过指定惟一索引<br/>C) 使用DISTINCTD)使用HAVING子句<br/>(31) 在Visual FoxPro中,以下有关SQL的SELECT语句的叙述中,错误的是<br/>A)SELECT子句中可以包含表中的列和表达式<br/>B)SELECT子句中可以使用别名<br/>C)SELECT子句规定了结果集中的列顺序<br/>D)SELECT子句中列的顺序应该与表中列的顺序一致<br/>(32) 下列关于SQL中HAVING子句的描述,错误的是<br/>A)HAVING子句必须与GROUP BY子句同时使用<br/>B)HAVING子句与GROUP BY子句无关<br/>C)使用WHERE子句的同时可以使用HAVING子句<br/>D)使用HAVING子句的作用是限定分组的条件<br/>(33) 在Visual FoxPro中,如果在表之间的联系中设置了参照完整性规则,并在删除规则中选择“限制”,则当删除父表中的记录时,系统反应是<br/>A) 不做参照完整性检查B) 不准删除父表中的记录<br/>C) 自动删除子表中所有相关的记录D) 若子表中有相关记录,则禁止删除父表中记录<br/>第(34)——(35)题使用如下三个数据库表<br/>学生表:S(学号,姓名,性别,出生日期,院系)<br/>课程表:C(课程号,课程名,学时)<br/>选课成绩表:SC(学号,课程号,成绩)<br/>在上述表中,出生日期数据类型为日期型,学时和成绩为数值型,其他均为字符型。<br/>(34) 用SQL命令查询选修的每门课程的成绩都高于或等于85分的学生的学号和姓名,正确的命令是<br/>A)SELECT 学号,姓名 FROM S WHERE NOT EXISTS;<br/>(SELECT * FROM SC WHERE SC.学号=S.学号 AND 成绩<85)<br/>B)SELECT 学号,姓名 FROM S WHERE NOT EXISTS;<br/>(SELECT * FROM SC WHERE SC.学号=S.学号 AND 成绩>=85)<br/>C)SELECT 学号,姓名 FROM S,SC;<br/>WHERE S.学号=SC.学号 AND 成绩>=85<br/>D)SELECT 学号,姓名 FROM S,SC;<br/>WHERE S.学号=SC.学号 AND ALL 成绩>=85<br/>(35) 用SQL语言检索选修课程在5门以上(含5门)的学生的学号、姓名和平均成绩,并按平均成绩降序排序,正确的命令是<br/>A)SELECT S.学号,姓名,平均成绩 FROM S,SC;<br/>WHERE S.学号=SC.学号;<br/>GROUP BY S.学号 HAVING COUNT(*)>=5 ORDER BY 平均成绩 DESC<br/>B)SELECT 学号,姓名,AVG(成绩) FROM S,SC;<br/>WHERE S.学号=SC.学号AND COUNT(*)>=5;<br/>GROUP BY 学号 ORDER BY 3 DESC<br/>C)SELECT S.学号,姓名,AVG(成绩) 平均成绩 FROM S,SC;<br/>WHERE S.学号=SC.学号AND COUNT(*)>=5;<br/>GROUP BY S.学号 ORDER BY 平均成绩 DESC<br/>D)SELECT S.学号,姓名,AVG(成绩) 平均成绩 FROM S,SC;<br/>WHERE S.学号=SC.学号;<br/>GROUP BY S.学号 HAVING COUNT(*)>=5 ORDER BY 3 DESC<br/>二、填空题(每空2分,共30分)<br/>请将每一个空的正确答案写在答题卡【1】~【15】序号的横线上,答在试卷上不得分。注意:以命令关键字填空的必须拼写完整。<br/>(1) 某二叉树中度为2的结点有18个,则该二叉树中有 【1】 个叶子结点。<br/>(2) 在面向对象方法中,类的实例称为 【2】 。<br/>(3) 诊断和改正程序中错误的工作通常称为 【3】 。<br/>(4) 在关系数据库中,把数据表示成二维表,每一个二维表称为 【4】 。<br/>(5) 问题处理方案的正确而完整的描述称为 【5】 。<br/>(6) 在奥运会游泳比赛中,一个游泳运动员可以参加多项比赛,一个游泳比赛项目可以有多个运动员参加,游泳运动员与游泳比赛项目两个实体之间的联系是 【6】 联系。<br/>(7) 执行命令A=2005/4/2之后,内存变量A的数据类型是 【7】 型。<br/>(8) 如下程序显示的结果是 【8】 。<br/>s=1<br/>i=0<br/>do while i<8<br/>s=s+i<br/>i=i+2<br/>enddo<br/>?s<br/>(9) 在Visual FoxPro中,可以在表设计器中为字段设置默认值的表是 【9】 表。<br/>(10) Visual FoxPro中数据库文件的扩展名(后缀)是 【10】 。<br/>(11)——(13)题使用如下三个数据库表:<br/>金牌榜.DBF国家代码 C(3),金牌数 I,银牌数 I,铜牌数 I<br/>获奖牌情况.DBF国家代码 C(3),运动员名称 C(20),项目名称 C(3),名次 I<br/>国家.DBF国家代码 C(3),国家名称 C(20)<br/>“金牌榜”表中一个国家一条记录;“获奖牌情况”表中每个项目中的各个名次都有一条记录,名次只取前3名,例如:<br/>国家代码运动员名称项目名称名次<br/>001刘翔男子110米栏1<br/>001李小鹏男子双杠3<br/>002费尔普斯游泳男子200米自由泳3<br/>002费尔普斯游泳男子400米个人混合泳1<br/>001郭晶晶女子三米板跳板1<br/>001李婷/孙甜甜网球女子双打1 </p><p>(11) 为表“金牌榜”增加一个字段“奖牌总数”,同时为该字段设置有效性规则:奖牌总数>=0,应使用SQL语句<br/>ALTER TABLE 金牌榜 【11】 奖牌总数I 【12】 奖牌总数>=0<br/>(12) 使用“获奖牌情况”和“国家”两个表查询“中国”所获金牌(名次为1)的数量,应使用SQL语句<br/>SELECT COUNT(*) FROM 国家 INNER JOIN 获奖牌情况;<br/>【13】 国家.国家代码=获奖牌情况.国家代码;<br/>WHERE 国家.国家名称=“中国” AND 名次=1<br/>(13) 将金牌榜.DBF中的新增加的字段奖牌总数设置为金牌数、银牌数、铜牌数三项的和,应使用SQL语句<br/>【11】 金牌榜 【10】 奖牌总数=金牌数+银牌数+铜牌数</p><p>参考答案:<br/>(1)D(2)B(3)D(4)C(5)A<br/>(6)C(7)B(8)D(9)D(10)C<br/>(11)B(12)D(13)A(14)B(15)A<br/>(16)D(17)A(18)B(19)A(20)C<br/>(21)D(22)A(23)D(24)B(25)C<br/>(26)A(27)B(28)C(29)C(30)C<br/>(31)D(32)B(33)D(34)A(35)D<br/>【1】19<br/>【2】对象<br/>【3】程序调试<br/>【4】关系<br/>【5】算法<br/>【6】多对多<br/>【7】数值<br/>【8】13<br/>【9】数据库表<br/>【10】.DBC<br/>【11】ADD<br/>【12】CHECK<br/>【13】ON<br/>【14】UPDATE<br/>【15】SET<br/></p>
[align=right][color=#000066][此贴子已经被作者于2006-4-3 9:17:04编辑过][/color][/align]
gnaw 2006-4-4 23:51
<p>参考答案:<br/>(1)D(2)B(3)D(4)C(5)A<br/>(6)C(7)B(8)D(9)D(10)C<br/>(11)B(12)D(13)A(14)B(15)A<br/>(16)D(17)A(18)B(19)A(20)C<br/>(21)D(22)A(23)D(24)B(25)C<br/>(26)A(27)B(28)C(29)C(30)C<br/>(31)D(32)B(33)D(34)A(35)D<br/>【1】19<br/>【2】对象<br/>【3】程序调试<br/>【4】关系<br/>【5】算法<br/>【6】多对多<br/>【7】数值<br/>【8】13<br/>【9】数据库表<br/>【10】.DBC<br/>【11】ADD<br/>【12】CHECK<br/>【13】ON<br/>【14】UPDATE<br/>【15】SET<br/></p>
123321a 2006-4-5 07:20
<p>这里也有标准答案:</p><p><a href="http://www.7788cn.net/bbs/dispbbs.asp?boardID=25&ID=73&page=1">http://www.7788cn.net/bbs/dispbbs.asp?boardID=25&ID=73&page=1</a></p>