1、国家二级 VF 机试(操作题)-试卷 168 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.(1)创建一个名为“订单管理”的数据库,并将已有的 employee、orders 和 customer 三个表添加到该数据库中。 (2)为 orders 表建立一个普通索引,索引名为 nf,索引表达式为“year(签订日期)”。 (3)为 employee 表建立主索引,为 orders 建立普通索引,索引名和索引表达式均为“职员号”。通过“职员号”在 employee 表和 orders 表之间建立一个一对多的永久联系。 (4)为上述建立的联系设置
2、参照完整性约束:更新规则为“限制”,删除规则为“级联”,插入规则为“限制”。(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.(1)根据“班级学生”库中的表用 SQL SELECT 命令查询学生的学号、姓名、课程号和成绩,结果按“课程号”降序排序,“课程号”相同时按“成绩”降序排序,并将查询结果存储到 cib 表中,将使用的 SQL语句保存到:mysq1txt 中。 (2)使用表单向导选择“学生”表生成一个名为 myform1 的表单。要求选择“学生”表中所有字段,表单样式为“浮雕式”;按钮类型为“图片按钮”;排序字段选择“学号”(降序);表单标题为“学生基本情况输入维护”。
3、(分数:2.00)_三、综合应用题(总题数:1,分数:2.00)3.对考生文件夹下的数据库“图书借阅”中的表完成如下操作: 为表 loans 增加一个字段“姓名”,字段类型为“字符型”,宽度为 8。 编写程序 modiproprg 实现以下功能: 根据 borrows 表的内容填写表 loans 中“姓名”的字段值。 查询表 loans 中 2008 年 2 月 3 日的借书记录,并将查询结果输入表 rqtable 中。 运行该程序。(分数:2.00)_国家二级 VF 机试(操作题)-试卷 168 答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.
4、(1)创建一个名为“订单管理”的数据库,并将已有的 employee、orders 和 customer 三个表添加到该数据库中。 (2)为 orders 表建立一个普通索引,索引名为 nf,索引表达式为“year(签订日期)”。 (3)为 employee 表建立主索引,为 orders 建立普通索引,索引名和索引表达式均为“职员号”。通过“职员号”在 employee 表和 orders 表之间建立一个一对多的永久联系。 (4)为上述建立的联系设置参照完整性约束:更新规则为“限制”,删除规则为“级联”,插入规则为“限制”。(分数:2.00)_正确答案:(正确答案:(1)命令窗口执行: MO
5、DIFY DATABASE 订单管理 ,创建数据库并打开数据库设计器。 数据库设计器中右击,选择【添加表】,在“打开”对话框中双击 employee 表添加到数据库中:以同样的方法,再将 orers 和 customer 表添加到数据库中。 (2)在数据库设计器中右击 oMers 表,选择【修改】,打开表设计器。 在表设计器的“索引”选项卡的“索引名”列输入 nf,“类型”设置为“普通索引”,“表达式”中输入“year(签订日期)”,单击“确定”按钮保存表结构修改。 (3)右击数据库设计器中的 employee 表,选择【修改】,打开表设计器,“字段”选项卡中选“职员号”,“排序”列中选择“升
6、序”,建立“职工号”的普通索引,在“索引”选项卡中修改“类型”为“主索引”,单击“确定”。 参照 employee 表的操作为 orders 表再建立“职员号”字段的普通索引。然后在数据库设计器中拖动 employee 表“索引”下方的主索引“职员号”到 orders 表中“索引”下方的普通索引“职员号”上,为两个表建立联系。 (4)选中两个表之间的关联线(被选中的连线会变粗),首先执行【数据库】【清理数据库】菜单命令,清空数据表中带有删除标记的记录,然后执行【数据库】【编辑参照完整性】菜单命令。 在打开的“参照完整性”对话框的表格中,选择“更新”下的单元格内容为“限制”;“删除”下的单元格内
7、容为“级联”;“插入”下的单元格内容为“限制”。单击“确定”按钮保存参照完整性的修改。)解析:解析:本题考查了数据库的建立及基本操作;表索引的建立;表间联系的建立;参照完整性设置。 利用 MODIFY DATABASE 命令可以新建数据库并打开数据库设计器,在数据库设计器中可以进行添加、新建和删除表等操作。数据库设计器中,建立联系前必须对两个表中进行连接的字段建立相关索引,并通过索引字段建立表间联系,在表设计器的“索引”选项卡中可以建立表索引。建立参照完整性前要先建立两个表的联系;建立联系后要先清理数据库,然后再设置参照完整性。二、简单应用题(总题数:1,分数:2.00)2.(1)根据“班级学
8、生”库中的表用 SQL SELECT 命令查询学生的学号、姓名、课程号和成绩,结果按“课程号”降序排序,“课程号”相同时按“成绩”降序排序,并将查询结果存储到 cib 表中,将使用的 SQL语句保存到:mysq1txt 中。 (2)使用表单向导选择“学生”表生成一个名为 myform1 的表单。要求选择“学生”表中所有字段,表单样式为“浮雕式”;按钮类型为“图片按钮”;排序字段选择“学号”(降序);表单标题为“学生基本情况输入维护”。(分数:2.00)_正确答案:(正确答案:(1) 步骤 1:命令窗口执行: MODIFY FILE mysql ,打开文本编辑器编写 SQL 命令。 步骤 2:在
9、编辑器中输入如下程序代码(以下程序是通过查询设计器生成): SELECT 学生学号,学生姓名,成绩课程号,成绩成绩; FROM 班级学生!学生 INNER JOIN 班级学生!成绩; ON 学生学号=成绩学号; ORDER BY 成绩课程号 DESC,成绩成绩 DESC;&查询结果先按“课程号“降序,再按“成绩“降序 INTO TABLE cjbdbf 步骤 3:在命令窗口执行命令:DO mysqltxt,执行文件(注意:执行文件时,文件后缀名txt 不能缺省)。 (2) 步骤 1:命令窗口执行: OPEN DATABASE 班级学生 ,打开数据库环境。 步骤 2:执行【文件】【新建】菜单命令
10、,或单击“常用”工具栏的“新建”按钮,在“新建”中选“表单”选项,单击“向导”图标按钮,“向导选取”中选“表单向导”项,单击“确定”按钮,启动表单向导。如图 337 所示。 步骤 3:“步骤 1-字段选取”界面的“数据库和表”下选中“学生”表,将“可用字段”全部添加到“选定字段”中,单击“下一步”按钮。如图 338 所示。 步骤 4:“步骤 2-选择表单样式”界面中选“样式”中的“浮雕式”,再在“按钮类型”中选“图片按钮”,单击“下一步”。如图 339 所示。 步骤 5:“步骤 3-排序次序”界面中双击“可用的字段或索引标识”中的“学号”到“选定字段”中,然后选中“降序”选项,单击“下一步”按
11、钮。如图 3-40 所示。 步骤 6:“步骤 4完成”界面中的“请键入表单标题”下方文本框中输入“学生基本情况输入维护”,单击“完成”按钮。如图 3-41 所示。 )解析:解析:(1)本题主要考查的是 SQL 联接查询。通过“学号”字段可以建立“学生”表和“成绩”表的联系,输出查询结果时,DESC 短语指定降序排序,通过 INTO TABLE 短语将查询结果输出到指定的表中保存。 (2)本题考查的是表单向导的使用启动向导前,先打开数据库环境,这样在添加数据表时,可在向导中直接选中。三、综合应用题(总题数:1,分数:2.00)3.对考生文件夹下的数据库“图书借阅”中的表完成如下操作: 为表 lo
12、ans 增加一个字段“姓名”,字段类型为“字符型”,宽度为 8。 编写程序 modiproprg 实现以下功能: 根据 borrows 表的内容填写表 loans 中“姓名”的字段值。 查询表 loans 中 2008 年 2 月 3 日的借书记录,并将查询结果输入表 rqtable 中。 运行该程序。(分数:2.00)_正确答案:(正确答案:步骤 1:命令窗口执行如下两条命令打开 loans 表结构。 USE loans &打开loans 表 MODIFY STRUCURE &打开表设计器 步骤 2:在表设计“字段”选项卡的“字段名”列的最后一个空白文本框中输入字段名“姓名”,“类型”中选择
13、“字符型”,“宽度”文本框中输入“8”,保存表结构修改。 步骤 3:命令窗口执行: MODIFY COMMAND MODIPROG , 打开程序文件编辑器,输入如下程序代码(以下 SQL 查询语句是通过查询设计器生成): SELECT 借书证号,姓名 FROM BORROWS INTO CURSOR TEMP DO WHILE NOT EOF() UPDATE LOANS SET LOANS姓名=TEMP姓名; WHERE LOANS借书证号=TEMP借书证号 SKIP ENDDO SELEC7*FROM LOANS WHERE 借书日 期=2008 一 0203); INTO TABLE R
14、QTABLE 步骤 5:执行命令: DO MODIPROGPRG ,执行程序。)解析:解析:本大题考查了表结构的修改:DO WHILE 循环语句;SQL 更新语句;SQL 简单查询。 表结构的修改可以在表设计器中或直接通过 SQL 语句修改表。本题基本思路如下: 首先通过简单查询检索BORROWS 表中的“借书证号”和“姓名”内容,将结果保存到临时表中,然后通过 DO WHILE 循环对临时表中的每条记录开始处理,利用 SQL-UPDATE 更新语句修改 LOANS 表中的“姓名”字段值,字段值等于临时表的“姓名”字段值,更新条件为 LOANS 表的“借书证号”等于临时表的“借书证号”;每处理完一条记录,记录指针便指向下一条记录,处理完临时表中所有记录后,退出 DO WHILE 循环;最后再通过 SQL简单查询检索 LOANS 表中借书日期等于“2008-02-03”的记录。