vfp第四章关系数据库标准语言SQL
VFP4
组 合 查 询 示 例
题目16:查询各系科教师工资总额、各系科每个教师的工资 以及全校所有教师工资总额。要求结果中包含三个列: 系名、姓名和工资,并按系名排序:
答案:
SELECT xim.ximing AS 系名, space(8) AS 姓名,sum(gz.jbgz) AS 工资; From xim inner join js inner join gz; On js.gh=gz.gh on xim.xdh=js.xdh; GROUP BY xim.ximing; UNION; SELECT xim.ximing AS 系名, js.xm AS 姓名, gz.jbgz AS 工资; From xim inner join js inner join gz; On js.gh=gz.gh on xim.xdh=js.xdh; UNION; SELECT '总额'+space(14) AS 系名 , space(8) AS 姓名 ,sum(gz.jbgz) AS 工资; From xim inner join js inner join gz; On js.gh=gz.gh on xim.xdh=js.xdh; order by 1
查询中的COUNT( )函数
• 题目3:在SJK数据库中,xs(学生)表xh(学 号)字段的前两位数字的含义为年级。要求设计 查询:按“年级”查询学生人数,输出字段为 “年级”和“人数”,按年级升序排序
•答案:
SELE LEFT(xs.xh,2) AS 年级 ,; COUNT(*) AS 人数 FROM SJK!xs GROUP BY 1; ORDER BY 1
定义 结果
单表查询
• 题目1:显示js.dbf表中所有教师的工 号和姓名 • 答案(SELECT-SQL) SELECT js.gh , js.xm FROM jxsj!js
第四章VF关系数据库标准语言SQL教案
第四章关系数据库标准语言SQLSQL:是结构化查询语言,它包括数据查询、数据定义、数据操纵、数据控制四部分。
但在VF中只绍介查询、定义、操纵三个方面。
SQL命令动词:SQL功能命令动词数据查询SELECT数据定义CREATE、DROP、ALTER数据操纵INSERT、UPDATE、DELETE数据控制GRANT、REVOKE一、查询功能1、SQL语言的核心是查询。
查询的基本形式:SELECT <字段名/表达式> FROM <表名/视图名> WHERE <条件> 由于表是由行和列组成就像数学中所学的坐标由X轴和Y轴构成,所需确定某个点需要说明X 为多少Y为多少。
而表中需要查询某些数据就必需指明行和列,所以在查询时:1FROM<表名/视图名>:说明查询的数据来自于所需要的表或视图。
若某于多个表时,各个表之间用逗号隔开。
2SELECT<字段名/表达式>:说明从表或视图中所查询结果是哪些字段名或表达式的值(各字段名或表达式之间用逗号隔开)即针对表的列来操作(限定列)。
3WHERE<条件>:说明从表或视图中所查询结果是哪些行即记录针对表的行来操作(限定行)。
关于其它短语的说明:短语说明表名.* 来自于某(些)表的所有字段(属性)DISTINCT 去掉查询结果中的重复记录(元组)IN 相当于数学集合“∈”只需属于其中一个元素(值)就是满足条件;NOT IN则不属于其中任意一个元素(值)就满足条件BETWEEN…AND 表示…和…之间,注意和第二章BETWEEN()函数的区别LIKE 字符串匹配运算符,注意通配符是“%”和“_”与第二章LIKE()函数区别ORDER BY 对指定某个(些)字段排序,只能对最终的查询结果排序,不能用于子查询GROUP BY用于分组计算查询(指定分组依据)HAVING对GROUP BY 分组计算查询的结果进一步的加以限定即限定分组(对分组之后的限定),必须跟GROUP 连用,不能单独使用。
第四章关系数据库标准语言sql(3)
三、表结构的修改
例1 为学生表增加一个字符型的政治面貌字段
ALTER TABLE 学生 ADD 政治面貌 C(8)
例2 修改选课表中的成绩字段的有效性规则为成 绩大于等于零小于等于100 100。 绩大于等于零小于等于100。
ALTER TABLE 选课 ALTER 成绩 N ; CHECK 成绩>=0 AND 成绩<=100 ; 成绩>=0 成绩<=100 ERROR”成绩应该在 成绩应该在0 100之间 之间” ERROR 成绩应该在0至100之间”
一、插入
2、格式二: 格式二: INSERT INTO dbf_name FROM ARRAY ArrayName|FROM MEMVAR ArrayName说明从指定的数组中插入记 FROM ARRAY ArrayName说明从指定的数组中插入记 录值; MEMVAR说明根据同名的内存变量来插入 录值;FROM MEMVAR说明根据同名的内存变量来插入 记录值,如果同名的变量不存在, 记录值,如果同名的变量不存在,那么相应的字段 为默认值或空值。 为默认值或空值。 例1:dimension dd(10) dd(1)=“WH4 WH4” dd(1)= WH4 dd(2)=“E7" dd(2)= E7" dd(3)=1500 …… insert into 职工 from array dd
二、表的删除
格式: 格式: DROP TABLE table_name 说明: table_name指定的 说明:直接从磁盘上删除 table_name指定的 表文件。 表文件。 注意:删除数据库中的表时, 注意:删除数据库中的表时,最好该数据库 处于打开状态。 处于打开状态。 例: DROP TABLE 职工
VF 关系数据库标准语言S Q L
关系数据库标准语言S Q L1、SQL是结构化的查询语言,是一种高度非过程化的语言。
查询是其核心。
注意:数据定义一般是对数据表操作,数据操纵一般是对表中的记录进行操作2、查询功能格式:SELE字段名……&&说明要查询的数据FROM数据表名(有联系的多个数据表名,有公共域)&&数据来源哪些表ON 联接的字段名WHERE连接条件……AND 条件……&&说明查询条件GROUP BY 分组(字段名)HAVING 分组条件&&查询结果分组ORDER BY 排序字段&&查询结果排序成绩管理数据库有以下三个数据库表:学生(学号C,姓名C,性别C,年龄N,系C……)选课(学号C,课程号C,成绩N……)课程(课程号C,课程名C……)1基于单个数据表,SELE…FROM …WHERE…(类似VF命令LIST FOR 条件)SELE 后面接要查询输出的字段名,多个用逗号分隔,全部可以用* FROM 后面是查询的数据表(单个数据表)WHERE 后面跟查询条件教材P130SELE 工资FROM 职工(从职工表中查询所有职工的“工资”字段值)SELE * FROM 职工(从职工表中查询所有职工的元组,*表示所有属性)SELE * FROM 职工WHERE 工资>1230(从职工表中查询工资大于1230的元组)注意:1、WHERE 后面的条件可以是任意复杂的条件表达式2、DISTINCT 短语消除结果中重复值(注意)列:查询成绩大于等于60分的学生的学号、课程号、成绩(学号,课程号,成绩都在选课表中)SELE 学号,课程号,成绩FROM 选课WHERE 成绩>=60相当于VF命令:LIST FIELDS 学号,课程号,成绩FOR 成绩>=60查询有考试成绩的学生的学号SELE DIST 学号FROM 选课(DIST 去掉重复)列:在学生表中查询2系年龄小于25的女同学的学号,姓名在学生表中查询2系或6系年龄小于25的男同学的学号,姓名分析条件:性别='女' AND 年龄<25 AND (系='6' OR 系='2')等于条件:性别='男' AND 年龄<25 AND 系='6' OR性别='男' AND 年龄<25 AND 系='2'-----------------------------------------------------------------------2)基于多个数据表(两个或三个),这些数据表肯定有联系(有公用字段),而且查询输出的字段可能在几个(两个或以上有联系)数据表中。
第四章 VF关系数据库标准语言SQL教案
第四章关系数据库标准语言SQLSQL:是结构化查询语言,它包括数据查询、数据定义、数据操纵、数据控制四部分。
但在VF中只绍介查询、定义、操纵三个方面。
SQL命令动词:一、查询功能1、SQL语言的核心是查询。
查询的基本形式:SELECT <字段名/表达式> FROM <表名/视图名> WHERE <条件> 由于表是由行和列组成就像数学中所学的坐标由X轴和Y轴构成,所需确定某个点需要说明X 为多少Y为多少。
而表中需要查询某些数据就必需指明行和列,所以在查询时:1FROM<表名/视图名>:说明查询的数据来自于所需要的表或视图。
若某于多个表时,各个表之间用逗号隔开。
2SELECT<字段名/表达式>:说明从表或视图中所查询结果是哪些字段名或表达式的值(各字段名或表达式之间用逗号隔开)即针对表的列来操作(限定列)。
3WHERE<条件>:说明从表或视图中所查询结果是哪些行即记录针对表的行来操作(限定行)。
关于其它短语的说明:可以在3个区域中创建SELECT命令。
1在命令窗口中;2在VFP程序中3在查询设计器中注:当FROM后面来自于多个表时,必须写连接条件(通常根据表的公共字段作为连接条件),此时在书写公共字段之前必须加以别名限定。
定义表的别名方法见教材P137,超连接的格式见教材P140FROM书写不要写成=>FORM二、查询方法:1、简单查询:例:从职工表中检索所有的工资值。
SELECT 工资FROM 职工表或者SELECT * FROM 职工表如果要去掉重复值用:DISTINCT例:检索哪些仓库有工资多于1260元的职工号SELECT DISTICT 仓库号FROM 职工表WHERE工资>12602、单击的连接查询:类似于多个表的查询,与嵌套查询的区别是要查询的结果呆以出自多个表中。
而嵌套查询的结果是基于一个表中。
例:找出工资多于1250元的职工号与他们所在的城市。
vf第四章关系数据库标准语言SQL
结果中有重复值,如果要 去掉重复值只需要指定DISTINCT短语:
SELECT DISTINCT 工资 FROM 职工 DISTINCT 短语的作用是去掉查询结果中 的重复值。
例4.2检索仓库关系中的所有元组。
sele * from 仓库
*代表要显示的所有字段
• HAVING短语必须跟随GROUP BY使用,它 用来限定分组必须满足的条件;
• ORDER BY短语用来对查询的结果进行排序。
4.2.1简单查询
基于单个表的查询,可以有简单的查询条件。这 样的查询由SELECT和FROM短语构成无条件查询, 或由SELECT 、 from 、 WHERE短语组成条件查询。 例4.1从职工表中检索所有工资值。 SELECT 工资 FROM 职工 SELECT 职工号,工资 FROM 职工
例4.7 找出工作在面积大于400的仓库的职工 号以及这些职工工作所在的城市。
SELE 职工号,城市 FROM 仓库,职工
WHERE(面积>400)AND(职工.仓库号= 仓库.仓库号)
4.2.3嵌套查询
基于多个关系的查询,这类查询所要求的结 果出自一个关系,但相关的条件却涉及多个关系。 例4.8哪些城市至少有一个仓库的职工工资为 1250元?
• 自然联接:当连接属性具有相同属性名,连接 条件取相等条件时,去掉得复属性的等值连接 称为自然连接。
SQL的核心是查询。SQL的查询命令也 称作SELECT命令,它的基本形式由 SELECT-FROM-WHERE查询块组成,多 个查询块可以嵌套执行。VFP的SQL SELECT命令的语法格式如下:(见书p128)
例4.3检索工资多于1230元的职工号。 Sele 职工号 from 职工 where 工资>1230
vfp第四章关系数据库标准语言SQL
USTS
计算机 基础教学部
目 录
1 2 3
4.1 4.2 4.3 4.4
SQL概述 查询功能 操作功能 定义功能
4
4.1 SQL概述
ISO采 纳SQL ANSI 提出SQL 1986年 1987年
4.2.4几个特殊运算符
例4.11:检索出工资在1220元到1240元范围内的职 工信息。 Select * from 职工 ; where 工资 between 1220 and 1240 例4.12:从供应商关系中检索出全部公司的信息 (不要工厂或其他供应商的信息)。 Select * from 供应商 ; where 供应商名 like “%公司”
例4.4:检索哪些仓库有工资多于1210的职工。
例4.5:给出在仓库“WH1”或“WH2”工作 并且工资少于1250员的职工号。
Select 职工号 from 职工 where (工资<1250 )and (仓库号=‘WH1’ or 仓库号=‘WH2’)
查询结果的去处:
INTO ARRAY ArrayName INTO CURSOR CursorName INTO TABLE|DBF TableName TO FILE FileName [ADDITIVE] TO PRINTER [PROMPT]
目 录
指定结果的范围
TOP nExpr[PERCENT]
4.2.1简单查询
例4.1:从职工 表中检索所有 工资值。
例4.2:检索仓库关系中的所有元组。
例4.3:检索工资多于1230的职工号。
VFP关系数据库标准语言SQL
一、选择题1、下面有关HAVING子句描述错误的是A) HAVING子句必须与GROUP BY子句同时使用,不能单独使用B) 使用HAVING子句的同时不能使用WHERE子句C) 使用HAVING子句的同时可以使用WHERE子句D) 使用HAVING子句的作用是限定分组的条件2、(15)~(27) 使用的数据如下:当前盘当前目录下有数据库db_stock,其中有数据库表stock.dbf,该数据库表的内容是:(15) 执行如下SQL语句后SELECT*FROM stock INTO DBF stock ORDER BY 单价A) 系统会提示出错信息B) 会生成一个按“单价”升序排序的表文件,将原来的stock.dbf文件覆盖C) 会生成一个按“单价”降序排序的表文件,将原来的stock.dbf文件覆盖D) 不会生成排序文件,只在屏幕上显示一个按“单价”升序排序的结果(16) 执行下列程序段以后,内存变量a的内容是CLOSE DATABASEa=0USE stockGO TOPDO WHILE.NOT.FOF()IF 单价>10a=a+1ENDIFSKIPENDDOA) 1 B) 3 C)5 D) 7(17) 有如下SQL SELECT语句SELECT*FROM stock WHERE单价BETWEEN 12.76 AND 15.20与该语句等价的是A) SELECT*FROM stock WHERE 单价<=15.20.AND.单价>=12.76B) SELECT*FROM stock WHERE 单价<15.20.AND.单价>12.76C) SELECT*FROM stock WHERE 单价>=15.20.AND.单价<=12.76D) SELECT*FROM stock WHERE 单价>15.20.AND.单价<12.76(18) 如果在建立数据库表stock.dbf时,将单价字段的字段有效性规则设为“单价>0”,通过该设置,能保证数据的A) 实体完整性 B) 域完整性 C) 参照完整性 D) 表完整性(19) 在当前盘当前目录下删除表stock的命令是A) DROP stock B) DELETE TABLE stockC) DROP TABLE stock D) DELETE stock(20) 有如下SQL语句SELECT max(单价) INTO ARRAY a FROM stock执行该语句后A) a[1]的内容为15.20 B) a[1]的内容为6B) a[0]的内容为15.20 C) a[0]的内容为6(21) 有如下SQL语句SELECT 股票代码,avg(单价) as 均价 FROM stock;GROUP BY 交易所 INTO DBF temp执行该语句后temp表中第二条记录的“均价”字段的内容是A) 7.48 B) 9.99 C)11.73 D) 15.20(22) 将stock表的股票名称字段的宽度由8改为10,应使用SQL语句A) ALTER TABLE stock股票名称 WITH c(10)B) ALTER TABLE stock股票名称 c(10)C) ALTER TABLE stock ALTER股票名称 c(10)D) ALTER stock ALTER 股票名称 c(10)(23) 有如下SQL语句CREATE VIEW stock_view AS SELECT*FROM stock WHERE 交易所=“深圳”执行该语句后产生的视图包含的记录个数是A) 1 B) 2 C)3 D) 4(24) 有如下SQL语句CREATE VIEW view_stock AS SELECT 股票名称AS名称,单价FROM stock 执行该语句后产生的视图含有的字段名是A) 股票名称、单价 B) 名称、单价C) 名称、单价、交易所 D) 股票名称、单价、交易所(25) 下面有关对视图的描述正确的是A) 可以使用MODIFY STRUCTURE命令修改视图的结构B) 视图不能删除,否则影响原来的数据文件C) 视图是对表的复制产生的D) 使用SQL对视图进行查询时必须事先打开该视图所在的数据库(26) 执行如下SQL语句后SELECT DISTINCT 单价 FROM stock;WHERE 单价=( SELECT min(单价)FROM stock) INTO DBF stock_x表stock_x中的记录个数是A) 1 B) 2 C)3 D) 4(27) 求每个交易所的平均单价的SQL语句是A) SELECT 交易所,avg(单价)FROM stock GROUP BY 单价B) SELECT 交易所,avg(单价)FROM stock ORDER BY 单价C) SELECT 交易所,avg(单价)FROM stock ORDER BY 交易所D) SELECT 交易所,avg(单价)FROM stock GROUP BY 交易所3、下列关于查询的说法中,不正确的是A)查询是预先定义好的一个SQL SELECT语句B)查询是Visual FoxPro支持的一种数据库对象C)通过查询设计器,可完成任何查询D)查询是从指定的表或视图中提取满足条件的记录,可将结果定向输出4、Visual FoxPro在SQL方面,不提供的功能是A)数据查询B)数据定义C)数据操纵D)数据控制5、检索职工表中工资大于800元的职工号,正确的命令是A)SELECT 职工号WHERE 工资>800B)SELECT 职工号FROM 职工SET 工资>800C)SELECT 职工号FROM 职工 WHERE 工资>800D)SELECT 职工号FROM 职工 FOR 工资>8006、找出在仓库面积大于500的仓库中工作的职工号,以及这些职工工作所在的城市,正确的命令是A)SELECT 职工号,城市 FROM职工;WHERE (面积>500) OR (职工.仓库号=仓库.仓库号)B)SELECT 职工号,城市 FROM职工;WHERE (面积>500) AND (职工.仓库号=仓库.仓库号)C)SELECT 职工号,城市 FROM仓库,职工;WHERE (面积>500) OR (职工.仓库号=仓库.仓库号)D)SELECT 职工号,城市 FROM仓库,职工;WHERE (面积>500) AND (职工.仓库号=仓库.仓库号)7、利用SQL语句,检索仓库中至少有一名职工的仓库信息,正确的命令是A) SELECT * FROM 仓库表 WHERE IN;(SELECT 仓库号 FROM 职工表)B) SELECT * FROM 仓库表 WHERE NOT IN;(SELECT 仓库号 FROM 职工表)C) SELECT * FROM仓库表WHERE 仓库号 EXISTS;(SELECT * FROM 职工表 WHERE 仓库号=仓库表.仓库号)D) SELECT * FROM 仓库表 WHERE EXISTS;(SELECT * FROM 职工表 WHERE 仓库号=仓库表.仓库号)8、第(32)~(35)题使用如下的设备表。
计算机二级VFP第4章(sql)
一、判断题(20分)1、SQL语句的核心是数据查询。
2、查询设计器默认的查询去向是浏览窗口。
3、使用sql语句进行分组查询时,为了去掉不满足条件的小组,应该在group by后面使用where子句。
4、查询设计器中的“筛选”选项卡对应于sql语句中的where。
5、在使用查询设计器时,如果是单表查询,连接选项卡是肯定不需要设置的。
6、在select语句中,可以使用eof()函数。
7、在sql中,修改数据表结构的命令是modify structure。
8、在sql的alter table命令中增加字段的子句是drop。
9、用insert-sql语句可以插入记录的部分字段值。
10、用insert-sql语句可以插入多条记录。
11、select-SQL可以为输出的字段重新命名。
12、select-SQL语句不能重新指定列的顺序。
13、用select-sql语句进行统计查询时,要统计学生表中女生的人数应使用函数count。
14、如果要在屏幕上直接看到查询的结果,“查询去向”应选择浏览或屏幕。
15、如果学生表中有“所在系”字段,要统计全系有多少个系,可以用命令子句select count(distinct 所在系)。
16、select-sql中,top子句必须放在order by子句之后。
17、在select-sql中,空值用null表示。
18、在sql中的delete命令功能是物理删除记录。
19、在用select-sql进行多表查询时,多表的连接分为内连接、左连接、右连接和完全连接。
20、select-sql可以将查询结果追加到已有的数据表中。
二、选择题(40分)1、在SQL语句中,与表达式“工资BETEEN 2000 AND 2800”功能相同的表达是()A、工资>=2000 and 工资>=2800B、工资>=2000 or 工资>=2800C、工资>=2000 and 工资<=2800D、工资>=2000 or 工资<=28002、不属于SQL数据定义功能的是()A、CREAT TABLEB、CREAT VIEWC、ALTER TABLED、UPDATE3、在SQL查询时,使用where子句指出的是()A、查询目标B、查询结果C、查询条件D、查询视图4、执行“select * from stock into stock stock order by 单价”()A、会产生一个按“单价”升序排列的文件。
vf关系数据库标准语言SQL
13
INTO
STUD
FROM
MEMVAR
4.3.2 更新记录命令
目 录
【格式】UPDATE <表文件名 SET <字段名 表文件名> 字段名1>=<表达式 [, 表达式> , 表文件名 字段名 表达式 <字段名 字段名2>=<表达式 表达式>…] [WHERE <条件 条件>] 字段名 表达式 条件
5
目 录
【 例 4-1】创建一个表STUD(学生信息表),它由以下字段组 】 成:学号 (C,10);姓名(C,8);性别(C,2);班级名 (C,10);系别代号(C,2);地址(C,50);出生日期 C 10 C 2 C 50 (D);是否团员 (L);备注 (M)。
上一页 下一页 退 出
CREATE TABLE STUD(学号 (10),姓名 C(10),性别 (学号C( ) ( ) C(2),班级名 C(10),系别代号 C(2),地址 C(50), ( ) ( ) 系别代号 ( ) 地址 ( ) 出生日期 D,是否团员 L,备注 M,照片 G) 是否团员 备注 照片 ) LIST STRUCTURE
第4章 关系数据库标准语言SQL
20122012-4-19 15
LIKE运算符是字符串匹配运算符, LIKE运算符是字符串匹配运算符,可以用 运算符是字符串匹配运算符 %”表示 个或多个字符, 表示0 “%”表示0个或多个字符,另外还有一个 通配符“_”表示一个字符 表示一个字符。 通配符“_”表示一个字符。 查询出地址不在北京的所有供应商信息。 例13 查询出地址不在北京的所有供应商信息。 SELECT *FROM 供应商 WHERE地址! WHERE地址 地址! =“北京 =“北京” 北京”
第 4章
关系数据库标准语言SQL 关系数据库标准语言SQL
本章要点
SQL概述以及特点 SQL概述以及特点 查询功能,简单查、简单的联接查询、 查询功能,简单查、简单的联接查询、嵌套查 SELECT中特殊运算符 排序、 询 、SQL SELECT中特殊运算符 、排序、简单 的计算查询、分组与计算查询、利用空值查询、 的计算查询、分组与计算查询、利用空值查询、 别名与自联接查询、 别名与自联接查询、内外层相互关联的嵌套查 使用量词和谓词的查询、超联接查询、 询、使用量词和谓词的查询、超联接查询、集 合的并运算
20122012-4-19
14
4.2.4 几个特殊运算符
1.LIKE和 between … and LIKE和 2.举例: 举例: 检索出工资在1220元到 元到1240元范围内的 例4.11 检索出工资在1220元到1240元范围内的 职工信息 select * from 职工 where 工资 between 1220 and 1240这个条件等价于(工资>=1220) and(工 1240这个条件等价于 工资>=1220) and(工 这个条件等价于( 资<=1240) 从供应商表中查询出全部公司的信息, 例4.12 从供应商表中查询出全部公司的信息, 不要工厂或其他供应商信息。 不要工厂或其他供应商信息。
VF教程第4章SQL关系数据库查询语言
第4章 章
SQL关系数据库查询语言 关系数据库查询语言
11
4.2 SQL的查询功能 4.2.3 联接查询
2.超联接查询 . SELECT… FROM <基本表名 基本表名>INNER|LEFT|RIGHT|FULL 基本表名 JOIN <基本表名 基本表名> 基本表名 ON <联接条件表达式 WHERE<条件表达式 联接条件表达式> 条件表达式>… 联接条件表达式 条件表达式
【例4.2】查询教师表中的所有信息。 】查询教师表中的所有信息。 SELECT * FROM 教师 命令中的*表示输出显示所有的字段 等价于如下语句: 表示输出显示所有的字段, 命令中的 表示输出显示所有的字段,等价于如下语句: SELECT 教师号 姓名 性别 职称 党员否 年龄 FROM 教师 教师号,姓名 性别,职称 党员否,年龄 姓名,性别 职称,党员否 【例4.3】查询教师表中男教师的姓名、职称和性别信息。 】查询教师表中男教师的姓名、职称和性别信息。 SELECT 姓名,职称 性别 FROM 教师 WHERE 性别="男" 姓名 职称,性别 性别 男 职称
功能一体化, 功能一体化,可以独立完成对数据库的所有操作 高度非过程化 自含式” 嵌入式” “自含式”和“嵌入式”使用方式 语言简洁, 语言简洁功能 功能 数据查询 数据定义 数据操纵 命令动词 SELECT CREATE、DROP、ALTER 、 、 INSERT、UPDATE、DELETE 、 、
第4章 章
SQL关系数据库查询语言 关系数据库查询语言
8
4.2 SQL的查询功能
3.去掉查询结果中的重复记录 .
字段名> 【格式】DISTINCT <字段名 格式】 字段名 说明】 语句后不能接表达式。 【说明】DISTINCT语句后不能接表达式。 语句后不能接表达式 【例4.6】查询学生表中都有哪些专业。 】查询学生表中都有哪些专业。 SELECT 专业 FROM 学生 利用DISTINCT语句可以去掉查询结果中的重复记录。 语句可以去掉查询结果中的重复记录。 利用 语句可以去掉查询结果中的重复记录 SELECT DISTINCT 专业 FROM 学生
全国VFP第四章SQL
P135页简单的计算查询 页简单的计算查询: 页简单的计算查询 计算平均值avg(cj) as 平均成绩 计算平均值 计算总分:sum(cj) as 总成绩 计算总分 求最高值:max(cj) as 最高分 求最高值 求最小值:min(cj) as 最低分 求最小值
求人数,门数 课程数 求人数 门数,课程数 门数 课程数:count(*) count(字段名 字段名) 字段名 count(distinct 字段名 的意思是计 字段名)的意思是计 数时,去掉结果中重复的记录, 数时,去掉结果中重复的记录,即结 果中重复的记录只算一条。体会: 果中重复的记录只算一条。体会: select count(xdh) from xs select count(distinct xdh ) from xs 注意不要把count()和sum()相混淆 相混淆. 注意不要把 和 相混淆 一个是求记录数,一个是求字段值加起 一个是求记录数 一个是求字段值加起 来的总和. 来的总和
三个表的相联语法
From 表1 JOIN 表2 JOIN 表3 On 表2.字段名=表3.字段名 字段名= 字段名 字段名 On 表1.字段名=表2 .字段名 字段名= 字段名 字段名 三个表相连接) (三个表相连接) 例子: 例子: Xs(xh,xm) cj(xh,kcdh,cj),kc(kcdh,kcm) From xs join cj join kc On cj. kcdh =kc.kcdh On xs.xh=cj.xh
4.求每个系男生人数 女生人数 输出字 求 个系男生人数,女生人数 男生人数 女生人数.输出字 男生人数,女生人数 段:xdh,男生人数 女生人数 答案 本题 男生人数 女生人数. 答案:本题 只按系分组,为什么不按 分组?因为 为什么不按xb分组 只按系分组 为什么不按 分组 因为 男人人数,女人数按 分组,是不能用两 女人数按xb分组 男人人数 女人数按 分组 是不能用两 列输出来的,组只能在一列输出. 列输出来的,组只能在一列输出 Select xdh,sum(iif(xb=‘男’,1,0)) as 男 男生人数,sum(iif(xb=‘女’,1,0)) as 女 男生人数 女 生人数 from xs group by xdh. 凡题目中出现两个组的计数在两列输 出的,或者一个总计数, 出的,或者一个总计数,一个部分计 数在两列输出的,都要用iif()计数 数在两列输出的,都要用 计数
《VisualFoxPro程序设计》第四章结构化查询语言SQL
其中各参数的说明如下:
• <表名1>:指定要修改的表的名称。
• [DROP <字段名>]:从表中删除指定字段。
• [SET CHECK <新有效性规则> [ERROR <出错信息>]]: 设置表的有效性规则,以及在不满足规则时的出错信息。
• [DROP CHECK]:删除表的有效性规则。
• [ADD PRIMARY KEY <字段表达式1> TAG <索引标识名1> [FOR <条件1>]]:为表建立主索引,一个表只能有一个 主索引。
SQL是Structured Query Language的缩写,属于一种一 体化语言,用于定义、查询、修改和控制关系型数据库 中的书籍。由于它功能强大,语言简洁,深受用户及计 算机工业界欢迎,被众多计算机公司和软件公司所采用。 经各公司的不断修改、扩充和完善,SQL语言最终发展成 为关系数据库的标准语言。1986年美国国家标准局ANSI 批准了SQL作为关系数据库语言的美国标准,1987年国际 标准化组织ISO也通过这一标准,1990言SQL 4.1 SQL语言概述 4.2 SQL的定义功能 4.3 SQL的查询功能 4.4 SQL的操作功能
提示:单击各个标题前的动画符号“ ” ,链接到相应的章节。
4.1 SQL语言概述
结构化查询语言(Structured Query Language)简称为 SQL,是关系数据库的标准语言。由于SQL语言具有功能 强大、使用方便灵活、语言简单易学等优点,目前几乎 所有的关系数据库管理系统软件都支持SQL。本章将详细 介绍Visual FoxPro中SQL语言各种主要功能的实现。
于100cm!”,班级 C(20))
VF_关系数据库标准语言SQL
第5章结构化查询语言(SQL)SQL概述SQL的内容在笔试和上机考试中均占到大约30%的比例,此外它还是查询和视图的基础,因此是学习的重点也是难点。
虽然SQL对大家来说有一定的难度,但是熟能生巧,大家把书中所涉及的题目和课件中的例题都理解并且操作了,相信SQL这个难关一定能攻克。
SQL是结构化查询语言Structure Query Language的缩写。
SQL包含了查询功能、数据定义、数据操纵和数据控制功能,在VFP中没有提供数据控制功能。
SQL主要特点:P861.SQL是一种一体化语言。
2.SQL是一种高度非过程化的语言。
3.SQL语言非常简洁。
4.SQL语言可直接以命令方式交互使用,也可嵌入到程序设计语言中以程序方式使用。
第四节数据查询功能SELECT命令的特点:1.可以自动打开数据库、表文件加以查询,而不需要事先用OPEN DA TABASE或USE命令打开。
2.可以直接选取数据表中的数据,而不需要事先用SET RELA TION命令建立关联。
3.当需要的索引文件不存在时,会自动建立暂存索引文件,以支持快速搜索技术(Rushmore)来查询。
4.其查询结果可输出到文件、表、屏幕或报表上,还可以转换成统计图表。
命令格式:SELECT ——FROM ——WHERE关系操作:投影,选择,联接。
说明:功能强大,语法灵活;要处理的数据表无须事先打开,通过FROM子句指明并打开。
1.SELECT 短语:说明要查询的数据;对应的关系操作为投影,类似于FIELDS子句。
2.FROM 短语:说明要查询的数据来自哪个或哪些表,可对单个表或多个表进行查询;3.WHERE 短语:说明查询条件;对应的关系操作为选择,类似于FOR子句。
如是多表查询还可能过该子句指明联接条件,进行联接。
4.GROUP BY 短语:用于对查询结果进行分组,可利用它进行分组汇总;类似于TOTAL命令。
5.HA VING 短语:跟随GROUP BY 使用,它用来限定分组必须满足的条件;6.ORDER BY 短语:用于对查询的结果进行排序;类似于SORT 命令。
vf第四章关系数据库标准语言SQL
vf第四章关系数据库标准语言SQL SQL(Structured Query Language),即结构化查询语言,是一种专门用于管理和操作关系数据库的标准语言。
本章将介绍SQL的基本语法和常用操作,包括数据查询、数据修改、数据删除和数据插入等。
下面将逐一详细介绍这些内容。
一、数据查询1.1 SELECT语句SELECT语句是SQL中最常用的查询语句,其基本语法如下所示:SELECT 列名 FROM 表名 WHERE 条件;其中,“列名”表示需要查询的列,可以使用“*”表示查询所有列;“表名”表示需要查询的表;“WHERE”子句用于设定查询条件,可以根据需要使用各种条件运算符(如“=、>、<、>=、<=、<>”)来进行查询。
示例如下:SELECT * FROM Employees;以上语句将查询名为“Employees”的表中的所有数据。
1.2 ORDER BY语句ORDER BY语句用于对查询结果进行排序,默认是按照升序排列,可以通过添加“DESC”关键字来改为降序排列。
示例如下:SELECT * FROM Employees ORDER BY Salary DESC;以上语句将按照“Salary”列对名为“Employees”的表中的数据进行降序排列。
二、数据修改2.1 UPDATE语句UPDATE语句用于修改表中的数据,其基本语法如下所示:UPDATE 表名 SET 列名=新值 WHERE 条件;其中,“表名”表示需要修改数据的表,“列名=新值”表示需要修改的列和对应的新值,“WHERE”子句用于设定需要修改的数据的条件。
示例如下:UPDATE Employees SET Salary=5000 WHERE EmployeeID=1001;以上语句将修改名为“Employees”的表中“EmployeeID”为1001的记录的“Salary”列的值为5000;2.2 DELETE语句DELETE语句用于删除表中的数据,其基本语法如下所示:DELETE FROM 表名 WHERE 条件;其中,“表名”表示需要删除数据的表,“WHERE”子句用于设定需要删除的数据的条件。
4关系数据库标准语言SQL
例4-12查询结果
例 4-12 查询结果
分组查询
【例4-13】 统计至少有两条销售记录的员工 的每次销售的平均数量。
SELECT 员工号,COUNT(*) AS 销售次数,AVG(数量) AS 平均数量; FROM 销售记录 GROUP BY 员工号 HAVING 销售次 数>=2
例4-13查询结果
例 4-19 改为全联接
联接查询
将例4-19中的联接分别改为全联接。
SELECT 姓名,销售记录.* FROM 销售员 FULL JOIN 销售记录 ; ON 销售员.员工号=销售记录.员工号
例4-19改为全联接的查询结 果
联接的查询结果
例 4-19 改为全联接的查询结果
指定查询去向
SQL SELECT语句默认在浏览窗口中显示查 询结果,可用INTO或TO字句指定查询结果 去向。
子查询
– 普通子查询 – 子查询相关的特殊运算
普通子查询
【例4-14】 查询每次销售数量不低 于平均销售数量的销售员的员工号。
SELECT DISTINCT 员工号 FROM 销售记录; WHERE 数量>(SELECT AVG(数量) FROM 销售记 录)
例4-14查询结果
例 4-14 查询结果
练习
查询入学分数大于平均分的学生信息
子查询相关的特殊运算
可使用下列与子查询相关的特殊运算:
–
–
表达式 IN (子查询):判断表达式的值是 否包含在查询结果中。 表达式 NOT IN (子查询):判断表达式 的值是否不包含在查询结果中。
子查询相关的特殊运算
– 表达式 比较运算符 ANY|ALL|SOME (子查 询):ANY和SOME作用相同,只要子查询 中有一个记录使比较运算结果为真,则结 果为真。 – [NOT] EXISTS (子查询):判断子查询是否 有返回结果。
《数据库应用基础 visual FoxPro》模块4 SQL语言
任务1 表的操作
模块4 SQL语言
二、修改表
1、添加新字段的命令 【格式】 ALTER TABLE | DBF 表名 ADD 字段名 字段类型[(字段宽度[,小数位数])] 【功能】
向指定的表中添加新字段。
任务1 表的操作
模块4 SQL语言
二、修改表
2、修改字段类型的命令 【格式】
ALTER TABLE | DBF 表名 ALTER 字段名 字段类型[(字段宽度[,小数位数])] 【功能】修改字段类型。
【功能】 向指定表中添加记录
任务2 记录的操作
模块4 SQL语言
二、修改记录
【格式】 UPDATE 表名 SET 字段名=表达式[,字段名=表达式……][WHERE 条件表达式] 【功能】更新表中的记录 【说明】不使用WHERE子句更新全部内容,使用WHERE子句更新满足条件的 记录。联接是多个关系表的查询,可以通过使用FROM和WHERE进行联接。
任务3 进行数据查询 四、ORDER BY 特殊选项查询
1、显示部分结果
模块4 SQL语言
2、将查询结果存入永久表(.DBF)中。
任务1 表的操作
模块4 SQL语言
二、修改表
3、修改字段名的命令 【格式】
ALTER TABLE | DBF 表名 RENAME COLUMN 原字段名 TO 新字段名 【功能】修改字段名
任务1 表的操作
二、修改表
4、删除字段的命令 【格式】 ALTER TABLE | DBF 表名 DROP COLUMN 字段名 【功能】删除已有字段。
Visual FoxPro数据库应用基础
模块4 SQL语言
学习目标: 1、理解SQL语言 2、了解数据控制命令 3、掌握数据定义、数据操纵命令 4、重点掌握数据查询命令
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
查 看 数 据 库 仓 库 管 理
4.2.5 排序
例4.15 先按仓库号排序,再按工资排序输出全部 职工信息。 Select * from 职工 order by 仓库号,工资
查 看 数 据 库 仓 库 管 理
4.2.6/7分组计算查询
第四章 Visual FoxPro 关系数据库标准语言 SQL 数据库程序设计
USTS
计算机 基础教学部
目 录
1 2 3
4.1 4.2 4.3 4.4
SQL概述 查询功能 操作功能 定义功能
4
4.1 SQL概述
ISO采 纳SQL ANSI 提出SQL 1986年 1987年
ISO提出 SQL89
ISO提出 SQL92
1989年
1992年
SQL功能
数据查询 数据定义 数据操纵 数据控制
命令动词 SELECT CREATE、DROP、ALTER INSERT、UPDATE、DELETE
GRANT、REVOKE
4.2.1 简单查询
4.2.2 简单的连接查询 4.2.3 嵌套查询 4.2.4 几个特殊的运算符 4.2.5 排序 4.2.6 简单的计算查询 4.2.7 分组与计算查询 4.2.8 利用空值查询 4.2.9 别名与自连接查询
SELECT SQL
定义 指定数据源表 数据源 确定源表间的联接
定义 结果 筛选源表记录 指定输出字段
FROM 子句
…JOIN…ON…子句 WHERE 子句 字段、函数和表达式的列表或*
指定输出类型
定义记录的分组 指定结果顺序 筛选结果记录 指定有无重复记录 指定结果的范围
INTO子句和TO子句
GROUP BY子句 ORDER BY子句 HAVING子句 ALL/DISTINCT TOP nExpr[PERCENT]
查 看 数 据 库 仓 库 管 理
4.2.1简单查询
例4.1:从职工 表中检索所有 工资值。
例4.2:检索仓库关系中的所有元组。
查 看 数 据 库 仓 库 管 理
例4.3:检索工资多于1230的职工号。
查 看 数 据 库 仓 库 管 理
例4.4:检索哪些仓库有工资多于1210的职工。
查 看 数 据 库 仓 库 管 理
Select 职工号,城市 from 仓库,职工; where (面积>400) and (职工.仓库号=仓库.仓库号)
Select 职工号,城市 from 仓库 inner join 职工; On (职工.仓库号=仓库.仓库号) where 面积>400
查 看 数 据 库 仓 库 管 理
查 看 数 据 库 仓 库 管 理
4.2.12超连接查询
SELECT …… from table inner | left |right | full join table On joincondition Where …… 例:普通连接
查 看 数 据 库 仓 库 管 理
例:列出每个职工经 手的具有最高金额 的订购单信息。
查 看 数 据 库 仓 库 管 理
Select out.职工号,out.供应商号,out.订购单号,out.订购日期,out.总金额;
from 订购单 out where 总金额=; (select max(总金额) from 订购单 inner1; where out.职工号=inner1.职工号)
查 看 数 据 库 仓 库 管 理
解决办法
查询和视图! 共同点 • 从表中检索或统计所需的数据 区别 • 查询是只读的;视图可以被修改,并且可以 将更新结果送回源表 • 查询以独立的文件存储;视图不以独立文件 存储,系统将其名称及定义存储在数据库中
查 看 数 据 库 仓 库 管 理
例:右连接
Select 仓库.仓库号,城市,面积,职工号,工资; from 仓库 right join 职工 on仓库.仓库号=职工.仓库号
查 看 数 据 库 仓 库 管 理
例:全连接
Select 仓库.仓库号,城市,面积,职工号,工资; from 仓库 full join 职工 on仓库.仓库号=职工.仓库号
目 录
1
2
4.1 4.2 4.3 4.4
SQL概述 查询功能 操作功能 定义功能
3
4
4.2.10内外层相关嵌套查询 4.2.11使用量词和谓词的查询 4.2.12超连接查询 4.2.13集合的并运算 4.2.14VFP中SELECT的几个特殊 选项
SELECT SQL
4.2.3嵌套查询
例4.9:查询所有职工的工资都多于1210元的仓库 的信息。 没有一个职工的工资少于或等于1210元的仓库 信息。 Select * from 仓库 where 仓库号 not in;
(select 仓库号 from 职工 where 工资<=1210) ;
例4.5:给出在仓库“WH1”或“WH2”工作 并且工资少于1250员的职工号。
查 看 数 据 库 仓 库 管 理
4.2.2简单连接查询
例4.7:找出 工作在面 积大于 400的仓 库的职工 号以及这 些职工工 作的城市。
查 看 数 据 库 仓 库 管 理
查 看 数 据 库 仓 库 管 理
例:检索有职工的工资大于或等于 WH1仓库中任何一名职工的工资的仓 库号。
Select distinct 仓库号 from 职工 ; where 工资>=any; ( select 工资 from 职工 where 仓库号=“WH1”)
查 看 数 据 库 仓 库 管 理
and 仓库号 in (select 仓库号 from 职工 )
4.2.4几个特殊运算符
例4.11:检索出工资在1220元到1240元范围内的职 工信息。 Select * from 职工 ; where 工资 between 1220 and 1240 例4.12:从供应商关系中检索出全部公司的信息 (不要工厂或其他供应商的信息)。 Select * from 供应商 ; where 供应商名 like “%公司”
在FROM子句中使用:<关系名> <别名> 雇员关系:雇员(雇员号,雇员姓名,经理)
雇员号 E3 E4 E6 E8
雇员姓名 赵勇 钱潮 孙洁 李渌
经理 E3 E3 E6
Select s.雇员姓名,“领导”,e.雇员姓名 ; from 雇员 s, 雇员 e where s.雇员号=e.经理
4.2.10内外层互相关嵌套查询
查 看 数 据 库 仓 库 管 理
问题
需要访问的数据涉及到多张表
查询学生名、课程名、成绩 xs.xm kc.kcm cj.cj
需要访问的只是部分数据
工商管理系的学生 xh, xm
需要访问计算或统计数据
每个学生的平均分 xs.xm 平均(cj.cj) 分组 xs.xm 每门课程80分以上的人数 kc.kcm 个数() 条件cj.cj>=80 分组cj.kcdh
查 看 数 据 库 仓 库 管 理
4.2.8利用空值查询
例4.23:找出尚未确定供应商的订购单。
Select * from 订购单 ; where 供应商号 is null
查 看 数 据 库 仓 库 管 理
4.2.9别名与自连接查询
4.2.11使用量词和谓词查询
tห้องสมุดไป่ตู้
<表达式> <比较运算符> [ANY|ALL|SOME] (子 查询)
ANY与SOME是同义词,在进行比较运算时只要 子查询中有一行能使结果为真,则结果为真。 ALL要求子查询中的所有行都能使结果为真时, 结果才为真。
查 看 数 据 库 仓 库 管 理
Count()、sum()、avg()、max()、min() 例:查询cj表中每个学生的考试门数、最高分、最 低分、平均分及总分,结果按学号升序排序。
Select cj.xh,count(*) as 考试门数, ; max(cj.cj) as 最高分,min(cj.cj) as 最低分,; avg(cj.cj) as 平均分,sum(cj.cj) as 总分 ; from cj ; group by cj.xh ; order by 1
SELECT [ALL | DISTINCT] [TOP nExpr [PERCENT]] [Alias.] Select_Item [AS Column_Name] [, [Alias.] Select_Item [AS Column_Name] ...] FROM [FORCE] [DatabaseName!]Table [[AS] Local_Alias] [[INNER | LEFT [OUTER] | RIGHT [OUTER] | FULL [OUTER] JOIN DatabaseName!]Table [[AS] Local_Alias] [ON JoinCondition …] [[INTO Destination] | [TO FILE FileName [ADDITIVE] | TO PRINTER [PROMPT] | TO SCREEN]] [PREFERENCE PreferenceName] [NOCONSOLE] [PLAIN] [NOWAIT] [WHERE JoinCondition [AND JoinCondition ...] [AND | OR FilterCondition [AND | OR FilterCondition ...]]] [GROUP BY GroupColumn [, GroupColumn ...]] [HAVING FilterCondition] [UNION [ALL] SELECT命令] [ORDER BY Order_Item [ASC | DESC] [, Order_Item [ASC | DESC] ...]]