文档详情

二级VFP_05第五章查询与视图.ppt

发布:2016-11-29约字共26页下载文档
文本预览下载声明
二级VFP程序设计教程 第五章 查询与视图 主讲老师:韩维良 * 第五章 查询与视图 第一节 查询 一、查询设计器 1、查询的概念 查询就是预先定义好的一个SQL SELECT 语句,在不同的场合可以直接或反复使用,从而提高效率。 查询:是从指定的表或视图中提取满足条件的记录,可按照需要定向输出查询结果,以扩展名为qpr的文件保存,是一个文本文件,它的主体是SQL SELECT语句。 2、用查询向导建立查询 ①、执行“文件”菜单中的“新建”,或单击“常用”工具栏上的“新建”按钮,选择“查询”,再选“向导”——“查询向导”,用查询向导建立查询。 例:用查询向导建立查询,显示仓库号、职工号、城市、工资等。 3、用查询设计器建立查询 ①、执行CREATE QUERY命令。 ②、执行“文件”菜单中的“新建”,或单击“常用”工具栏上的“新建”按钮。 在”新建”对话框中,选择”查询”并单击”新建文件”打开查询设计器建立查询。 ③、在项目管理器的“数据”选项卡下选择“查询”,单击“新建”命令。 还可以直接编辑.qpr文件中SELECT语句建立查询。 打开查询设计器后,其中的各选项卡内容如下: “字段”选项卡对应于SELECT短语,指定所要查询的数据,这时可以单击“全部添加”选择所有字段,也可以逐个选择字段“添加”;在函数和表达式“编辑框中可以输入或编辑计算表达式,如“职工.工资*12”,再单击添加。 “联接“选项卡对应于JOIN ON短语,用于编辑联接条件。 “筛选”选项卡对应于WHERE短语,用于指定查询条件。 “排序依据”选项卡对应于ORDER BY短语,用于指定排序的字段和排序方式。 “分组依据”选项卡对应于GROUP BY短语和HAVING短语,用于分组。 “杂项”选项卡可以指定是否要重复记录(对应于DISTLNCT)及列在前面的记录(对应于TOP短语)等。 例:用查询设计器建立查询,显示仓库号、职工号、城市、工资等。 也可以将上章中学习的SQL语句拿来练习。 〖例〗 哪些城市至少有一个仓库的职工工资为1250元(工资和城市字段不在一个表中) SELECT城市 FROM 仓库 WHERE 仓库号 IN ; (SELECT 仓库号 FROM 职工 WHERE 工资=1250) 二、运行查询 方法:DO 查询文件名.qpr 在查询设计器中,右击选“运行查询”。 运行查询一般是在浏览器中显示结果,但是设计查询的目的不只是为了完成一种查询功能,因此我们还可以根据需要为查询输出定位查询去向。 方法:“查询”菜单→“查询去向”,或者,查询设计器工具栏中的查询去向按钮,或者右击选“查询去向”。 在“查询去向”对话框中有7个按钮: “浏览”:在“浏览”窗口中显示查询结果。 “临时表”:将查询结果存储在一个临时只读表中。 “表”:将查询结果保存为一个命名的表。 “图形”:使查询结果可用于Microsoft Graph(Graph是包含在Visual FoxPro中的一个独立的应用程序),也可以用查询向导建立查询图表(向导中选择“图形向导”)。 “屏幕”:在Visual FoxPro主窗口或当前活动输出窗口中显示查询结果。 “报表”:将输出送到一个报表文件(.FRX)。 “标签”:将输出送到一个标签文件(.LBX)。 三、查看查询对应的Select语句 在查询设计器中,右击选“查看SQL”. 也可执行如下命令直接编辑命令: modi command 查询文件名.qpr 第二节 视图 一、视图的概念 视图是从表或其它视图中导出的表,它本身不独立存储在数据库中,数据库中只存放视图的定义(即数据词典)而不存放视图对应的数据,这些数据仍存放在导出视图的基本表中,因此视图是一个虚表。 视图并不存放任何真正的数据,只存放查询指令。打开视图时,执行其中的指令,生成虚拟表。 视图只能存放在数据库中,并不以一个独立文件的形式存在。 视图兼有“表”和“查询”的特点: 与查询类似的地方是:可以用来从一个或多个相关联的表中提取有用的信息; 与表类似的地方是:可以用来更新其对应的表中的数据,并将更新结果永久保存在磁盘上; 在Visual FoxPro中,视图分为“本地视图”和“远程视图”两种。“本地视图”的数据源来自本地机,而“远程视图”的数据源可以通过Microsoft的ODBC驱动程序从异地机上获取。 二、建立视图 1、用视图向导建立视图 方法:执行“文件”菜单中的“新建”,或单击“常用”工具栏上的“新建”按钮,选择“视图”,再选“向导”。 例:用视图向导建立视图,显示仓库号、职工号、城市、工资等。 过程与查询基本类同,只是比查询多了一个更新选项卡。 2、用视图设计器建立视图 ①、 用CREATE VIEW命令打开视图设计
显示全部
相似文档