




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Visual FoxPro程序设计教程,讲师:徐红波 E-mail: x_h_,在软件开发中经常用到数据的查询,如学生成绩管理、人事档案、图书检索等软件,查询的准确性、速度直接影响软件的质量、效率、应用及维护。 VFP开发工具用三种途径解决查询问题:用查询设计器建立查询;用视图设计器建立视图;用SQL语句查询。,第4章 查询与视图,4.1 概念4.1.1 查询,使用查询设计器,从数据库表或自由表中获取有用数据,经过对查询条件、查询要求的设置,形成一个后缀为qpr的文件,通过do命令来执行。,用视图设计器从数据库表中获取有用数据,与查询一样经过查询条件、查询要求的设置形成视图。视图是以视图名的形
2、式存在数据库中。视图中数据的更新可以使源表相应数据更新。视图的执行要在数据库中执行。,4.1.2 视图,SQL语言是关系数据库的标准语言。它是结构化的查询语言。它集数据定义语言、数据操纵语言、数据控制语言的功能为一体。,4.1.3 SQL查询,4.2 SQL语句4.2.1 SELECT查询语句,1、基本语句 格式:SELECT INTO DBF|TABLE FROM WHERE 功能:从表名列表的表中查询符合条件的,按的形式显示。若选INTO DBF|TABLE 子句,查询结果存入新表。,说明:格式: ALL|DISTINCTTOP PERCENT别名.列名 AS 栏目名,别名.列名 AS 栏
3、目名 ALL|DISTINCT子句:ALL输出结果有重复记录,是子句默认值。DISTINCT输出结果无重复记录。 TOP PERCENT子句: TOP 是符合条件的内容中取前个记录。PERCENT是取前面分之个记录。 别名.列名 AS 栏目名,别名.列名 AS 栏目名子句:列名可以是字段、含字段的表达式。指定输出结果中的字段,此子句也可用*代替此时显示表中所有字段。,例4.1 SELECT基本语句应用,open database 学生 select * from 学生 select * from 学生 into table 学生y select 姓名, 入学成绩 from 学生 where 入
4、学成绩=500 select distinct 性别 from 学生 select 学生.学号, 学生.姓名, 学生成绩.数学 from 学生, 学生成绩 where 学生.性别=女 and 学生成绩.数学=60 and 学生.学号=学生成绩.学号 select top 2 * from 学生 order by 学号 close database all,2、SELECT中常用的系统函数,在实际应用中经常有统计、求平均值、汇总等操作。SQL提供一些常用的系统函数。,3、SELECT分组子句,格式: GROUP BY , , HAVING 功能:对查询结果进行分组。HAVING 为指定分组必须满
5、足的条件,例4.2 分组查询应用,open database 学生 select avg(入学成绩) from 学生 select count(*) from 学生 select sum(入学成绩) from 学生 group by 性别 having 性别=女,4、排序子句,格式: ORDER BY ASC|DESC, ASC|DESC 功能:查询结果按关键字排序,ASC升序为默认值,DESC为降序,例4.3 查询排序应用,open database 学生 select 学号, 姓名, 入学成绩 from 学生 order by 入学成绩 desc select 学生.学号, 学生.姓名,
6、学生成绩.英语 from 学生, 学生成绩 where 学生.学号=学生成绩.学号 order by 学生成绩.英语 select avg(入学成绩) as “入学成绩平均分” from 学生 group by 性别 order by 入学成绩 desc close database all,5、嵌套查询,嵌套查询就是在SELECT语句中套用SELECT语句,被套在内的SELECT子句通常称为子查询,(1)IN等谓词及比较运算符结合使用,例4.4 IN与NOT IN在嵌套查询中的应用 open database 学生 select * from 学生 where 学号 in (select 学
7、号 from 学生成绩 where 英语=90) select * from 学生 where 学号 not in (select 学号 from 学生成绩 where 英语90) close database all,例4.5 比较运算符在嵌套查询中的应用,open database 学生 select * from 学生 a1 where 入学成绩=(select 入学成绩 from 学生 a2 where a1.学号=a2.学号 and 入学成绩=500) close database all,(2)使用量词和谓词的嵌套查询,格式: ANY|ALL|SOME (子查询) NOT EXIS
8、T (子查询) 说明:ANY、ALL、SOME为量词,ANY与SOME是同义词,在查询中,只要子查询有一行能使结果为.T.,则结果就为.T.。ALL要求子查询中所有行结果为.T.时,结果才能为.T.。EXIST或NOT EXIST是检查在子查询中是否有结果返回。EXIST为有结果返回为真否则为假。NOT EXIST刚好与EXIST相反。,例4.6 查询数学成绩高于90分的学生的学号,姓名,open database 学生 select 学号, 姓名 from 学生 where exist (select * from 学生成绩 where 学号=学生.学号 and 数学=90) close d
9、atabase all,例4.7 查找比所有入学成绩小于500分学生的年龄都小的学生,open database 学生 select * from 学生 where 出生 all (select 出生 from 学生 where 入学成绩500) close database all,6、几个特殊运算符,(1)BETWEEN AND运算符 格式:BETWEEN AND 说明:表示在一个区间范围内,例4.8 查询入学成绩480-600分学生情况,与不在500-600之间的学生,open database 学生 select * from 学生 where 入学成绩 between 490 and
10、 600 select * from 学生 where 入学成绩 not between 490 and 600 close database all,(2)LIKE运算符,LIKE后含有%或_通配符的字符型表达式。%表示0个或多个字符,_表示一个字符。,例4.9 查询姓王的所有学生情况,查询姓名前两个字为王丽的学生情况,open database 学生 select * from 学生 where 姓名 like “王%” select * from 学生 where 姓名 like “王丽_” close database all,7、连接查询,格式: LEFT|RIGHT|FULL JO
11、IN ON ,(1)LEFT JOIN为左连接,在满足连接条件的记录出现在结果中基础上,第一个表不满足条件的记录也出现在结果中。,例4.11 用左连接查找学生表与学生成绩表 open database 学生 select * from 学生 left join 学生成绩 on 学生.学号=学生成绩.学号 close database all,(2)RIGHT JOIN为右连接,在满足连接条件的记录出现在结果中基础上,第二个表不满足条件的记录也出现在结果中,例4.12 用右连接查找学生表与学生成绩表 open database 学生 select * from 学生 right join 学生成
12、绩 on 学生.学号=学生成绩.学号 close database all,(3) FULL JOIN为全连接。即满足连接条件的记录出现在结果上,两表不满足连接条件的记录也出现在结果上,4.13 用全连接查找学生表与学生成绩表 open database 学生 select * from 学生 full join 学生成绩 on 学生.学号=学生成绩.学号 close database all,8、UNION子句,用此子句可以将多个表的查询结果,合并成一个结果,要求查询结果具有相同字段与个数,且对应字段类型要兼容。例如: select * from 学生 where 性别=女 union al
13、l select * from 学生 where 性别=男,9、查询结果的存放,(1)用INTO DBF|TABLE 可将查询结果存放表中 (2)用INTO ARRAY 将查询结果存入数组 (3)用INTO CURSOR 将查询结果存入临时表 (4)用TO FILE ADDITIVE将结果存入文本文件,用ADDITIVE将结果追加到由指定的文本文件尾部。否则将覆盖原有文件,例4.15 关于结果存放的应用,open database 学生 select * from 学生 into table 新学生 select * from 学生 into array a select * from 学生
14、into cursor 临时学生 select * from 学生 to file 学生文本 close database all,4.2.2 操作功能(插入、更新、删除),1、插入 格式1:INSERT INTO 字段1,字段2, VALUES (表达式1, 表达式2) 格式2: INSERT INTO FROM ARRAY 数组名 | MEMVAR 功能:在表尾添加一个指定字段的记录 说明:(1)格式1中字段名1,字段名2是用于指定添加记录的字段名,如省略,说明所有字段,表达式1,表达式2是添加字段1,字段2的具体值。(2)格式2ARRAY数组名是从指定的数组中添加记录的值,MEMVAR是
15、从与字段同名的内存变量中添加记录的值,例4.16 插入应用,open database 学生 use 学生成绩 insert into 学生成绩 values (“105010120”, 90, 80, 72) go 1 scatter memvar insert into 学生成绩 from memvar go 2 scatter to a insert into 学生成绩 from array a,2、更新,格式:UPDATE SET 字段名1=,字段名2= WHERE 功能:更新满足条件的记录的值,若省略WHERE,更新全部记录的值,例4.17 更新应用,use 学生成绩 update
16、学生成绩 set 数学=数学+10 where 数学80 update 学生成绩 set 英语=英语+10 use,3、删除,格式: DELETE FROM WHERE 功能:删除符合条件的记录,若省略WHERE将删除全部记录,例4.18 删除应用,use 学生成绩 delete from 学生成绩 where 英语100 use,4.3 查询,4.3.1 建立查询 1、用向导建立查询 2、用查询设计器建立查询 4.3.2 执行查询 1、用界面执行查询 2、用命令执行查询 DO ,4.3.3 查询设计器的局限性,用查询设计器建立的查询简单、易学,但在使用中有一定的局限性,它适用于比较规范的查询
17、,而对较复杂的查询是无法实现的。,例4.22 查询入学成绩最高学生的信息,open database 学生 select a1.学号, a1.姓名, a1.入学成绩 from 学生 as a1 where 入学成绩=(select max(入学成绩) from 学生 as b1 where a1.学号=b1.学号) close database all,4.4 视图查询,视图与查询均是从表中获取数据。视图与查询的区别:视图是一张虚表,数据库中只存放视图的定义,数据库不存放视图的对应数据,这些数据仍然存放在表中。而查询是以qpr文件形式存放在磁盘中。更新视图的数据同时更新表的数据,这一点与查询是完全不同的。,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 代理供货混凝土合同样本
- 借名买房 合同标准文本
- 人工服务购销合同范例
- 企业营销咨询合同样本
- 个人房东写合同样本
- 公司购买合同样本
- 人保保险合同样本
- 公司入股股合同样本
- 中医馆招聘合同样本
- 国家电网未来技术展望试题及答案
- 2024-2030年中国玄武岩纤维工业行业现状调研及投资战略研究报告
- 公园景观修复零星维修施工方案
- 挂靠免责协议书范本
- 小学数学青岛版五年级下册《异分母分数大小比较与通分》课件
- 社区矫正考试题及答案
- 幼儿园水池建设方案
- 安徽省宿州市省、市示范高中2024-2025学年高一上学期期中教学质量检测英语试题 含解析
- 《驾驶室固定矩形窗》
- 2024-2030年中国盐差能行业面临的困境分析及投资规模研究报告
- 架构驱动医疗变革
- 2024年化学检验员(中级)职业技能鉴定考试题库-上(单选题)
评论
0/150
提交评论