首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载 | ||
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试 MPA考试 | 中科院 |
||
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT 新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语 |
||
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证 华为认证 | Java认证 |
||
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格 报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师 人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平 驾驶员 | 网络编辑 |
||
卫生资格 | 执业医师 | 执业药师 | 执业护士 | ||
会计从业资格考试(会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师 注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师 |
||
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师 质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师 设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师 城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师 |
||
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏 |
三、综合应用(1小题,计30分)
在考生文件夹下有股票管理数据库stock_6,数据库中有stock_mm表和stock_cs表,stock_mm的表结构是股票代码C(6)、买卖标记L(.T.表示买进,.F.表示卖出),单价N(7.2)、本次数量N(6)。tock_cs的表结构是股票代码C(6),买入次数N(4),最高价N(7.2)。stock_mm表中一只股票对应多个记录,stock_cs表中一只股票对应一个记录(stock_cs表开始时记录个数为0)
请编写并运行符合下列要求的程序:
(1)设计一个名为stock_m菜单,菜单中有两个菜单项"计算"和"退出"。
程序运行时,单击"计算"菜单项应完成的操作是计算每支股票的买入次数和 (买入时的)最高价存入stock_cs表中,买卖标记.T.(表示买进)
(注意:stock_cs表中的记录按股票代码从小到大的物理顺序存放)。
(2)根据stock_cs表计算买入次数最多的股票代码和买入次数存储到的stock_x表
中(与stock_cs表对应字段名称和类型一致)。
单击"退出"菜单项,程序终止运行。
本题主要考核点:
菜单的建立、结构化查询语言(SQL)中的联接查询、查询的排序、分组查询、临时表的概念、查询结果的去向等知识点。
本题解题思路:
第一步:利用菜单设计器定义两个菜单项,在菜单名称为"计算"的菜单项的结果列中选择"过程",并通过单击"编辑"按钮打开一个窗口来添加"计算"菜单项要执行的命令。在菜单名称为"退出"的菜单项的结果列中选择"命令",并在后面的"选项"列中输入以下退出菜单的命令:SET SYSMENU TO DEFAULT
第二步:在单击"计算"菜单项后面的"编辑"按钮所打开的窗口中添加如下的过程代码:
SET TALK OFF &&在程序运行时关闭命令提示
SET SAFETY OFF &&不出现文件重名的提示
OPEN DATABASE STOCK_6 &&打开数据库文件STOCK_6
SELECT 股票代码,COUNT(*) AS 买入次数,MAX(单价) AS 最高价;
FROM STOCK_MM;
WHERE 买卖标记;
GROUP BY 股票代码;
ORDER BY 股票代码;
INTO ARRAY AFieldsValue
&&要得到的结果集是在买入的股票中统计的,所以要用WHERE 进行限制
&&由于要得到每支股票的买入次数及买入时的最高价,所以要用到SELECT语句的分组查询,
&&这里要以股票代码作为分组的依据,所以要将GROUP BY 股票代码 放在WHERE的后面
&&要以股票代码从小到大的顺序进行排序要用到ORDER BY股票代码;由于要得到的是买入的次数
&&买入时的最高价所以这里要用到聚合函数COUNT和MAX,COUNT()函数可得到组中项目的数量,
&&MAX()函数可得到最大值
DELETE FROM STOCK_CS
&&删除STOCK_CS中以前的记录
&&DELETE SQL语句来删除表中的记录
&& DELETE FROM [数据库名!]表名
&&[WHERE 条件表达式11 [AND | OR 条件表达式2 ...]]
INSERT INTO STOCK_CS FROM ARRAY AfieldsValue
&&INSERT SQL语句向表中追加记录
&&INSERT SQL语句基本样式为:INSERT INTO 表名 (字段名1,字段名2,…)
&&VALUES (表达式1,表达式2,...)
&&另有一种可以从一个数组中数据追加到表中或从一些和字段名相同的内存变量
&&INSERT INTO 表名 FROM ARRAY 数组名 | FROM MEMVAR
USE STOCK_CS
PACK
&&物理删除已打删除标记的记录
USE
SELECT * TOP 1 FROM STOCK_CS ORDER BY 买入次数 DESC INTO TABLE STOCK_X
&&在SELECT SQL语句中可以指定结果集返回的行数 TOP n [PERCENT],如果没有PERCENT
&& n指定返回的行数,如果指定PERCENT指定返回的百分比
&& 可以利用INTO TABLE 表名 将返回的结果集存入一个永久表中
SET SAFETY ON
SET TALK ON
第三步:以stock_m为文件名保存菜单,并生成菜单,最后运行生成的菜单。
相关推荐:2010年9月计算机等级考试冲刺备考指导专题北京 | 天津 | 上海 | 江苏 | 山东 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
广东 | 河北 | 湖南 | 广西 | 河南 |
海南 | 湖北 | 四川 | 重庆 | 云南 |
贵州 | 西藏 | 新疆 | 陕西 | 山西 |
宁夏 | 甘肃 | 青海 | 辽宁 | 吉林 |
黑龙江 | 内蒙古 |