求VFP笔试试题或“面向对象数据库技术”试题

求VFP笔试试题或“面向对象数据库技术”试题,第1张

二00五年四月

全国计算机等级考试二级笔试试卷

Visual FoxPro程序设计

(考试时间:90分钟,满分100分)

一、选择题( (1)~(35) 每题2分,共70分)

下列各题A) 、B) 、C) 、D) 四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。

(1) 数据的存储结构是指

A) 存储在外存中的数据 B) 数据所占的存储空间量

C) 数据在计算机中的顺序存储方式 D) 数据的逻辑结构在计算机中的表示

(2) 下列关于栈的描述中错误的是

A) 栈是先进后出的线性表

B) 栈只能顺序存储

C) 栈具有记忆作用

D) 对栈的插入与删除 *** 作中,不需要改变栈底指针

(3) 对于长度为n的线性表,在最坏的情况下,下列各排序法所对应的比较次数中正确的是

A) 冒泡排序为n/2 B) 冒泡排序为n

C) 快速排序为n D) 快速排序为n(n-1)/2

(4) 对于长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为

A) log2n B) n/2 C) n D) n+1

(5) 下列对于线性链表的描述中正确的是

A) 存储空间不一定是连续,且各元素的存储顺序是任意的

B) 存储空间不一定是连续,且前件元素一定存储在后件元素的前面

C) 存储空间必须是连续,且前件元素一定存储在后件元素的前面

D) 存储空间必须是连续,且各元素的存储顺序是任意的

(6) 下列对软件测试的描述中正确的是

A) 软件测试的目的是证明程序是否正确

B) 软件测试的目的是使程序运行结果正确

C) 软件测试的目的是尽可能多地发现程序中的错误

D) 软件测试的目的是使程序符合结构化原则

(7) 为了使模块尽可能独立,要求

A) 模块的内聚程度要尽量高,且各模块间的藕合程度要尽量强

B) 模块的内聚程度要尽量高,且各模块间的藕合程度要尽量弱

C) 模块的内聚程度要尽量低,且各模块间的藕合程度要尽量弱

D) 模块的内聚程度要尽量低,且各模块间的藕合程度要尽量强

(8) 下列描述中正确的是

A) 程序就是软件 B) 软件开发不受计算机系统的限制

C) 软件既是逻辑实体,又是物理实体 D) 软件是程序、数据与相关文档的集合

(9) 数据独立性是数据库技术的重要特点之一,所谓数据独立性是指

A) 数据与程序独立存放

B) 不同的数据被存放在不同的文件中

C) 不同的数据只能被对应的应用程序所使用

D) 以上三种说法都不对

(10) 用树型结构表示实体之间联系的模型是

A) 关系模型 B) 网络模型 C) 层次模型 D) 以上三个都是

(11) 在创建数据库表结构时,给该表指定了主索引,这属于数据完整性中的

A) 参照完整性 B) 实体完整性

C) 域完整性 D) 用户定义完整性

(12) 在创建数据库表结构时,为该表中一些字段建立普通索引,其目的是

A) 改变表中记录的物理顺序 B) 为了对表进行实体完整性的约束

C) 加快数据库表的更新速度 D) 加快数据库表的查询速度

(13) 数据库系统中对数据库进行管理的核心软件是

A) DBMS B) DB C) OS D) DBS

(14) 设有两个数据库表,父表和子表之间是一对多的联系,为控制子表和父表的关联,可以设置“参照完整性规则”,为此要求这两个表

A) 在父表连接字段上建立普通索引,在子表连续字段上建立主索引

B) 在父表连接字段上建立主索引,在子表连续字段上建立普通索引

C) 在父表连接字段上不需要建立任何索引,在子表连接字段上建立普通索引

D) 在父表和子表的连接字段上都要建立主索引

(15) 关系运算中的选择运算是

A) 从关系中找出满足给定条件的元组的 *** 作

B) 从关系中选择若干个属性组成新的关系的 *** 作

C) 从关系中选择满足给定条件的属性的 *** 作

D) A和B都对

(16) 在指定字段或表达式中不允许出现重复值的索引是

A) 惟一索引 B) 惟一索引和候选索引

C) 惟一索引主索引 D) 主索引候选索引

(17) 在Visual FoxPro中,以下关于删除记录的描述中,正确的是

A) SQL的DELETE命令在删除数据库表中的记录之前,不需要用USE命令打开表

B) SQL的DELETE命令和传统Visual FoxPro的DELETE命令在删除数据库表中的记录之前,都需要用USE命令打开表

C) SQL的DELETE命令可以物理的删除数据库表中的记录,而传统Visual FoxPro的DELETE命令只能逻辑删除数据库表中的记录

D) 传统Visual FoxPro的DELETE命令在删除数据库表中的记录之前不需要用USE命令打开表

(18) 在Visual FoxPro中,如果希望跳出SCAN…ENDSCAN循环体、执行ENDSCAN后面的语句,应使用

A) LOOP语句 B) EXIT语句

C) BREAK语句 D) RETURN语句

(19) 打开数据库abc的正确命令是

A) OPEN DATABASE abc B) USE abc

C) USE DATABASE abc D) OPEN abc

(20) 在Visual FoxPro中,下列关于表的叙述正确的是

A) 在数据库表和自由表中,都能给字段定义有效性规则和默认值

B) 在自由表中,能给表中的字段定义有效性规则和默认值

C) 在数据库表中,能给表中的字段定义有效性规则和默认值

D) 在数据库表和自由表中,都不能给字段定义有效性规则和默认值

(21) Visual FoxPro的“参照完整性”中“插入规则“包括的选择是

A) 级联和忽略 B) 级联和删除 C) 级联和限制 D) 限制和忽略

(22) 在Visual FoxPro中,关于查询和视图的正确描述是

A) 查询是一个预先定义好的SQL SELECT语句文件

B) 视图是一个预先定义好的SQL SELECT语句文件

C) 查询和视图都是同一种文件,只是名称不同

D) 查询和视图都是一个存储数据的表

(23) 在Visual FoxPro中,以下关于视图描述中错误的是

A) 通过视图可以对表进行查询 B) 通过视图可以对表进行更新

C) 视图是一个虚表 D) 视图就是一种查询

(24) 使用SQL语句将学生表S中年龄(AGE)大于30岁的记录删除,正确的命令是

A) DELETE FOR AGE > 30 B) DELETE FROM S WHERE AGE > 30

C) DELETE S FOR AGE > 30 D) DELETE S WHERE AGE > 30

(25) 在Visual FoxPro中,使用LOCATE FOR <expL>命令按条件查找记录,当查找到满足条件的第一条记录后,如果还需要查找下一条满足条件的记录,应使用

A) 再次使用LOCATE FOR <expL>命令 B) SKIP命令

C) CONTINUE 命令 D) GO命令

(26) 在Visual FoxPro中,删除数据库表S的SQL命令是

A) DROP TABLE S B) DELETE TABLE S

C) DELETE TABLE SDBF D) ERASE TABLE S

(27) 下列表达式中,表达式返回结果为的是F的是

A) AT(“A”,“BCD”) B) “[信息]”$“管理信息系统”

C) ISNULL(NULL) D) SUBSTR(“计算机技术”,3,2)

(28) 使用SQL语句向学生表S(SNO,SN,AGE,SEX)中添加一条新记录,字段学号(SNO)、姓名(SN)、性别(SEX)、年龄(AGE)的值分别为0401、王芳、女、18,正确命令是

A) APPEND INTO S (SNO,SN,SEX,AGE)VALUES(‘0401’,‘王芳’,‘女’,18)

B) APPEND S VALUES(‘0401’,‘王芳’,18,‘女’)

C) INSERT INTO S(SNO,SN,SEX,AGE)VALUES(‘0401’,‘王芳’,‘女’,18)

D) INSERT S VALUES(‘0401’,‘王芳’,18,‘女’)

(29) 假设某个表单中有一个命令按钮cmdClose,为了实现当用户单击此按钮时能够关闭该表单的功能,应在该按钮的Click事件中写入语句

A) ThisFormClose B) ThisFormErase

C) ThisFormRelease D) ThisFormReturn

(30) 在SQL的SELECT查询结果中,消除重复记录的方法是

A) 通过指定主关系键 B) 通过指定惟一索引

C) 使用DISTINCT子句 D) 使用HAVING子句

(31) 在Visual FoxPro中,以下有关SQL的SELECT语句的叙述中,错误的是

A) SELECT子句中可以包含表中的列和表达式

B) SELECT子句中可以使用别名

C) SELECT子句规定了结果集中的列顺序

D) SELECT子句中列的顺序应该与表中列的顺序一致

(32) 下列关于SQL中HAVING子句的描述,错误的是

A) HAVING子句必须与GROUP BY子句同时使用

B) HAVING子句与GROUP BY子句无关

C) 使用WHERE子句的同时可以使用HAVING子句

D) 使用HAVING子句的作用是限定分组的条件

(33) 在Visual FoxPro中,如果在表之间的联系中设置了参照完整性规则,并在删除规则中选择了“限制”,则当删除父表中的记录时,系统反应是

A) 不做参照完整性检查

B) 不准删除父表中的记录

C) 自动删除子表中所有相关的记录

D) 若子表中有相关记录,则禁止删除父表中记录

第(34)-(35)题使用如下三个数据库表:

学生表:S(学号,姓名,性别,出生日期,院系)

课程表:C(课程号,课程名,学时)

选课成绩表:SC(学号,课程号,成绩)

在上述表中,出生日期数据类型为日期型,学时和成绩为数值型,其他均为字符型。

(34) 用SQL命令查询选修的每门课程的成绩都高于或等于85分的学生的学号和姓名,正确的命令是

A) SELECT 学号,姓名 FROM S WHERE NOT EXISTS;

(SELECT FROM SC WHERE SC学号 = S学号 AND成绩 < 85)

B) SELECT 学号,姓名 FROM S WHERE NOT EXISTS;

(SELECT FROM SC WHERE SC学号= S学号 AND >= 85)

C) SELECT 学号,姓名 FROM S,SC

WHERE S学号= SC学号 AND成绩 >= 85

D) SELECT 学号,姓名 FROM S,SC

WHERE S学号 = SC学号 AND ALL成绩 >= 85

(35) 用SQL语言检索选修课程在5门以上(含5门)的学生的学号、姓名和平均成绩,并按平均成绩降序排列,正确的命令是

A) SELECT S学号,姓名 平均成绩 FROM S,SC;

WHERE S学号 = SC学号;

GROUP BY S学号 HAVING COUNT()>=5 ORDER BY平均成绩 DESC

B) SELECT 学号,姓名,AVG(成绩) FROM S,SC;

WHERE S学号 = SC学号 AND COUNT()>=5;

GROUP BY 学号 ORDER BY 3 DESC

C) SELECT S学号,姓名 AVG(成绩) 平均成绩FROM S,SC;

WHERE S学号 = SC学号 AND COUNT()>=5;

GROUP BY S学号 ORDER BY平均成绩 DESC

D) SELECT S学号,姓名 AVG(成绩)平均成绩 FROM S,SC;

WHERE S学号 = SC学号;

GROUP BY S学号 HAVING COUNT()>=5 ORDER BY 3 DESC

二、填空题( 每空2分,共30分)

请将每一个空的正确答案写在答题卡1~15序号的横线上,答在试卷上不得分。

注意:以命令关键字填空的必须拼写完整。

(1) 某二叉树中度为2的结点有18个,则该二叉树中有1 个叶子结点。

(2) 在面向对象方法中,类的实例称为 2 。

(3) 诊断和改正程序中错误的工作通常称为 3 。

(4) 在关系数据库中,把数据表示成二维表,每一个二维表称为 4 。

(5) 问题处理方案的正确而完整的描述称为 5 。

(6) 在奥运会游泳比赛中,一个游泳运动员可以参加多项比赛,一个游泳比赛项目可以有多个运动员参加,游泳运动员与游泳比赛项目两个实体之间的联系是 6 联系。

(7) 执行命令A=2005/4/2之后,内存变量A的数据类型是 7 型。

(8) 如下程序显示的结果是 8 。

s=1

i=0

do while i<8

s=s+i

i=i+2

enddo

s

(9) 在Visual FoxPro 的中,可以在表设计器中为字段设置默认值的表是 9 表。

(10) Visual FoxPro 中数据库文件的扩展名(后缀)是 10 。

(11)-(13)题使用如下三个数据库表:

金牌榜DBF 国家代码C(3), 金牌数I, 银牌数I, 铜牌数I

获奖牌情况DBF 国家代码C(3), 运动员名称C(20), 项目名称C(30), 名次I

国家DBF 国家代码 C(3), 国家名称C(20)

“金牌榜”表中一个国家一条记录:“获奖牌情况”表中每个项目中的各个名次都有一条记录,名次只取前3名,例如:

国家代码 运动员名称 项目名称 名次

001刘翔男子110米栏1

001李小鹏男子双杠3

002非尔普斯游泳男子200米自由泳3

002非尔普斯游泳男子400米个人混合泳1

001郭晶晶女子三米板跳板1

001李婷/孙甜甜网球女子双打1

(11) 为表“金牌榜”增加一个字段“奖牌总数”,同时为该字段设置有效性规则:奖牌总数>=0,应使用SQL语句

ALTER TABLE金牌榜 11 奖牌总数I 12 奖牌总数>=0

(12) 使用“获奖牌情况”和“国家”两个表查询“中国”所获金牌(名次为1)的数量,应使用SQL语句

SELECT COUNT() FROM 国家 INNER JOIN 获奖牌情况;

13 国家国家代码 = 获奖牌情况国家代码;

WHERE 国家国家名称 = “中国” AND 名次 = 1

(13) 将金牌榜DBF中新增加的字段奖牌总数设置为金牌数、银牌数、铜牌数三项的和,应使用SQL语句

14 金牌榜 15 奖牌总数 = 金牌总数+银牌数+铜牌数

5SELECT 学号,姓名,专业

FROM 学生表

WHERE 课程号 NOT IN 'C135'

GO

6 SELECT 学号,姓名,课程名,分数

FROM 学生表,课程表,成绩表

WHERE (学生表学号=成绩表学号,成绩表课程号=成绩表课程号,课程表课程名='英语)'

GO

7SELECT 学号,姓名,专业,分数

FROM 学生表 ,成绩表

WHERE (学生表学号=成绩表学号,分数 BETWEEN 90 AND 100)

GO

8 CREATE TABLE S

GO

10select 学号,姓名,性别

FROM 学生表

WHERE 学生表班级 = '04电子商务',姓名 LIKE '张%'

GO

其他的也不难 我是学了一学期的,现在要考试了,这些有的还是有问题的 哦,全是自己临场写的 ,锻炼我的SQL 语句的书写

还行,我当时用的也是希塞的教材,但是感觉比不上软考指定教材,如果已经买了就看吧,还没买的话还是推荐买指定教材。希塞的这个书没有下午题,如果想要下午题可以网上下载历年真题,上午下午题都有。也可以去买希塞的一本习题册,是专门的下午题,既有真题也有模拟题。

试题二(15分)

阅读下列说明,回答问题1至问题5,将解答填入答题纸的对应栏内。

[说明]

某企业网上销售管理系统的数据库部分关系模式如下所示:

客户(客户号,姓名,性别,地址,邮编)

产品(产品号,名称,库存,单价)

订单(订单号,时间,金额,客户号)

订单明细(订单号,产品号,数量)

关系模式的主要属性及约束如表2-1所示。

表2-1关系模式的主要属性及约束

关系名 约束

客户 客户号唯一标识一位客户,客户性别取值为“男”或者“女’

产品 产品号唯一标识一个产品

订单 订单号唯一标识一份订单。一份订单必须且仅对应一位客户,一份订单可由一到多条订单明细组成。一位客户可以有多份订单。

订单明细 一条订单明细对应一份订单中的一个产品

客户、产品、订单和订单明细关系及部分数据分别如表2-2、2-3、2-4、2-5所示。

表2-2客户关系

客户号 姓名 性别 地址 邮编

Ol 王晓丽 女 南京路2号 200005

02 林俊杰 男 北京路18号 200010

表2-3产品关系

产品号 名称 库存 单价

01 产品A 20 29800

02 产品B 50 16800

表2-4订单关系

订单号 时间 金额 客户号

1001 20060203 126800 01

1002 20060203 29800 02

表2-5订单明细关系

订单号 产品号 数量

1001 01 2

1001 02 4

1002 01 1

[问题1](3分)

以下是创建部分关系表的SQL语句,请将空缺部分补充完整。

CREATE TABLE 客户(

客户号CHAR(5)___(a)___

姓名CHAR(30),

性别CHAR(2)___(b)___

地址CHAR(30),

邮编CHAR(6));

CREATE TABLE 订单(

订单号CHAR(4),

时间 CHAR(10),

金额 NUMBER(6,2),

客户号 CHAR(5) NOT NULL,

PRIMARY KEY(订单号),

___(c)___;

[问题2](4分)

请根据如下查询语句,回答问题(d),(e)和(f)

SELECT 客户号

FROM 订单,订单明细

WHERE 订单明细订单号 = 订单订单号 AND

产品号 = "02’AND

数量>10;

(d)上述查询语句的功能是什么请简要回答。(30个字以内)

(e)将上述查询语句转换成对应的关系代数表达式。

(f)上述SQL查询语句是否可以进一步优化如可以,给出优化后的SQL查询语句。

[问题3](3分)

请按题意将下述SQL查询语句的空缺部分补充完整。

按客户购买总额的降序,输出每个客户的客户名和购买总额。

SELECT 客户客户名,___(g)___

FROM 客户,订单

WHERE 客户客户号 = 订单客户号

___(h)___

___(i)___;

[问题4](3分)

用SQL语句完成下述要求。

(1)定义一个描述订单的客户号和对应订单明细中产品号关系的视图,客户产品(客户号,产品号)。

(2)借助(1)所定义的视图,查询至少购买了01号客户购买的所有产品的客户号。

SELECT 客户号

FROM 客户产品 客户产品1

WHERE___(j)___

(SELECT

FROM客户产品 客户产品2

WHERE___(k)___

(SELECT

FROM客户产品 客户产品3

WHERE___(l)___));

[问题5](2分)

当—个订单和对应的订单明细数据入库时,应该减少产晶关系中相应的产品库存,为此应该利用数据库管理系统的什么机制实现此功能请用100字以内的文字简要说明。

1、补充完善题目中的数据库相应描述信息,并据此分析得到相应的实体—联系图(E-R图)。

2、根据E-R图得出相应的关系模式,并进行适当的规范化(规范化到3NF)。

3、创建一个数据库,并将2中得到的关系模式转换成数据库中相应的表。

4、 给创建好的各个表添加好主键约束、外键约束,并视情况添加相应的唯一约束、默认值约束、检查约束等以保证数据的完整性。

下面还有追加问题~问题补充:

5、 给数据库中合适的表上创建至少一个索引。

6、 至少创建一个用户自定义函数,并将其绑定到合适的表上。

7、 至少创建一个视图。

8、 至少创建一个用户存储过程(可视具体情况决定是否带相应的参数)。

9、 至少创建一个触发器。

本大题还有3个问题,请各位高手作答。

1、 补充完善题目中的数据库相应描述信息,并据此分析得到相应的实体—联系图(E-R图)。

2、 根据E-R图得出相应的关系模式,并进行适当的规范化(规范化到3NF)。

3、 创建一个数据库,并将2中得到的关系模式转换成数据库中相应的表。

我不会做~

以上就是关于求VFP笔试试题或“面向对象数据库技术”试题全部的内容,包括:求VFP笔试试题或“面向对象数据库技术”试题、急救!谁帮我做一下数据库的模拟试卷、数据库系统工程师考试历年试题分析与解答(第4版)怎么样好像没有数据库的试题,里面只有上午的试题吗等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10105150.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存