SQL语言SELECT 语句及其子句
sql中select语句详解及用途

sql中select语句详解及用途1 2 3 4 5 6 7 8 9 10 11SELECT [ ALL | DISTINCT [ ON ( expression [, ...] ) ] ]* | expression [ AS output_name ] [, ...][ FROM from_item [, ...] ][ WHERE condition ][ GROUP BY expression [, ...] ][ HAVING condition [, ...] ][ { UNION | INTERSECT | EXCEPT } [ ALL ] select ][ ORDER BY expression [ ASC | DESC | USING operator ] [, ...] ] [ FOR UPDATE [ OF tablename [, ...] ] ][ LIMIT { count | ALL } ][ OFFSET start ]这里 from_item 可以是:1 2 3 4 5 6 7 8[ ONLY ] table_name [ * ][ [ AS ] alias [ ( column_alias_list ) ] ]|( select )[ AS ] alias [ ( column_alias_list ) ]|from_item [ NATURAL ] join_type from_item[ ON join_condition | USING ( join_column_list ) ]输入expression表的列/字段名或一个表达式.output_name使用 AS 子句为一个列/字段或一个表达式声明另一个名称.这个名称主要用于标记输出列用于显示。
它可以在 ORDER BY 和 GROUP BY 子句里代表列/字段的值.但是 output_name 不能用于 WHERE 或 HAVING 子句;用表达式代替.from_item一个表引用,子查询,或者 JOIN 子句.详见下文.condition一个布尔表达式,给出真或假的结果.参见下面描述的 WHERE 和 HAVING 子句.select一个选择语句,可以有除 ORDER BY,FOR UPDATE,和 LIMIT 子句以外的所有特性(甚至在加了括弧的情况下那些语句也可以用).FROM 项可以包括:table_name一个现存的表或视图的名字.如果声明了 ONLY,则只扫描该表.如果没有声明ONLY,该表和所有其派生表(如果有的话)都被扫描.可以在表名后面跟一个 * 来表示扫所有其后代表,但在目前的版本里,这是缺省特性.(在 PostgreSQL 以前的版本里, ONLY 是缺省特性.)alias用于于前面的 table_name. 的替换名字,用于缩写或消除一个表自连接时的含混.(此时同一个表要扫描好几次.)如果写了别名,那么你也可以写一个字段别名列表,为表的一个或者几个字段提供替换名字.select一个在 FORM 子句里出现的子查询.它的输出作用好象是为这条 SELECT 命令在其生存期里创建一个临时表.请注意这个子查询必须用园括弧包围.并且必须给它加别名.join_type[ INNER ] JOIN, LEFT [ OUTER ] JOIN, RIGHT [ OUTER ] JOIN, FULL [ OUTER ] JOIN,或 CROSS JOIN. 之一.就 INNER 和 OUTER 连接类型,必须出现 NATURAL ON join_condition,或 USING ( join_column_list ) 之一.对于 CROSS JOIN,上面的项都不能出现.join_condition一个条件限制.类似 WHERE 条件,只不过它只应用于在这条 JOIN 子句里连接的两个 from_item.join_column_list一个 USING 字段列表 (a, b, ... ) 是 ON 条件 = AND = ... 的缩写.输出Rows你声明的查询返回的所有结果集的行.count查询返回的行的计数.描述SELECT 将从一个或更多表中返回记录行。
sql语句子句执行顺序

sql语句⼦句执⾏顺序
由于是⾮计算机科班出⾝,因此,缺了很多计算机⽅⾯的知识。
很多东西都是⼯作后遇到了求助度娘后才了解的,尤其是数据库这⼀块,⼀直是块⼼病。
今天看了下《SQL从⼊门到精通》,其中说到了sql各⼦句的执⾏顺序。
以前在⼀个⼤神的博客中也有看到,讲的很详细,但是由于已经找不到那个博客,今天⾃⼰将其记录下来。
了解sql各⼦句的执⾏顺序,是写出⾼质量的sql代码的基础。
各⼦句的执⾏顺序如下:
1) FROM⼦句。
2) WHERE⼦句。
3) GROUP BY⼦句。
4) HAVING⼦句。
5) SELECT⼦句。
6) ORDER BY⼦句。
SELECT 语句的各⼦句中FROM ⼦句是⾸先被执⾏的,通过FROM ⼦句获得⼀个虚拟表,然后通过WHERE ⼦句从刚才的虚拟表中获取满⾜条件的记录,⽣成新的虚拟表。
将新虚拟表中的记录通过GROUP BY ⼦句分组后得到更新的虚拟表,⽽后HAVING ⼦句在最新的虚拟表中筛选出满⾜条件的记录组成另⼀个虚拟表。
从上⼀步得到的虚拟表中,SELECT ⼦句根据select_list 将指定的列提取出来组成更新的虚拟表,最后ORDER BY ⼦句对其进⾏排序得出最终的虚拟表。
通常,⼈们将最终的虚拟表称为查询结果集。
SELECT语句的完整语法为(精)

SELECT 语句的完整语法为:SELECT[ALL|DISTINCT|DISTINCTROW|TOP]{*|talbe.*|[table.]field1[AS alias1][,[table.]field2[AS alias2][,… ]]}FROM tableexpression[,… ][IN externaldatabase][WHERE… ][GROUP BY… ][HAVING… ][ORDER BY… ][WITH OWNERACCESS OPTION]说明:用中括号 ([]括起来的部分表示是可选的,用大括号 ({}括起来的部分是表示必须从中选择其中的一个。
1 FROM子句FROM 子句指定了 SELECT 语句中字段的来源。
FROM 子句后面是包含一个或多个的表达式 (由逗号分开 ,其中的表达式可为单一表名称、已保存的查询或由INNER JOIN 、 LEFT JOIN 或 RIGHT JOIN 得到的复合结果。
如果表或查询存储在外部数据库,在 IN 子句之后指明其完整路径。
例:下列 SQL 语句返回所有有定单的客户:SELECT OrderID,Customer.customerIDFROM Orders CustomersWHERE Orders.CustomerID=Customers.CustomeersID2 ALL、 DISTINCT 、 DISTINCTROW 、 TOP 谓词(1 ALL 返回满足 SQL 语句条件的所有记录。
如果没有指明这个谓词,默认为ALL 。
例:SELECT ALL FirstName,LastNameFROM Employees(2 DISTINCT 如果有多个记录的选择字段的数据相同,只返回一个。
(3 DISTINCTROW 如果有重复的记录,只返回一个(4 TOP显示查询头尾若干记录。
也可返回记录的百分比,这是要用 TOP N PERCENT子句(其中 N 表示百分比例:返回 5%定货额最大的定单SELECT TOP 5 PERCENT*FROM [ Order Details]ORDER BY UnitPrice*Quantity*(1-Discount DESC3 用 AS 子句为字段取别名如果想为返回的列取一个新的标题,或者,经过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用 AS 保留。
select语句的基本语法和查询条件表示方法

一、select语句的基本语法在SQL中,select语句用于从数据库中检索数据。
它有以下基本语法:1. select子句:指定要从数据库中检索的列。
例如:SELECT column1, column2, ...FROM table_name;2. from子句:指定要检索数据的表名。
例如:SELECT column1, column2, ...FROM table_name;3. where子句:指定检索数据的条件。
例如:SELECT column1, column2, ...FROM table_nameWHERE condition;4. order by子句:指定检索数据的排序方式。
例如:SELECT column1, column2, ...FROM table_nameORDER BY column1;二、查询条件表示方法在select语句中,可以使用不同的查询条件来指定要检索的数据。
常见的查询条件表示方法有以下几种:1. 等于:使用等号表示要检索的数据等于指定的值。
例如:SELECT column1, column2, ...FROM table_nameWHERE column1 = value;2. 不等于:使用不等号表示要检索的数据不等于指定的值。
例如:SELECT column1, column2, ...FROM table_nameWHERE column1 != value;3. 大于/小于:使用大于号或小于号表示要检索的数据大于或小于指定的值。
例如:SELECT column1, column2, ...FROM table_nameWHERE column1 > value;4. 区间:使用between和and表示要检索的数据在指定的区间内。
例如:SELECT column1, column2, ...FROM table_nameWHERE column1 BETWEEN value1 AND value2;5. 空值:使用IS NULL或IS NOT NULL来检索空值或非空值的数据。
sql select用法

sql select用法
SQL Select用法
1. SELECT子句:
SELECT子句用于从表或视图中检索信息,可以检索一列或多列,也可以指定各种条件,按特定的顺序来检索信息。
语法:
SELECT列名称 FROM表名称 WHERE 条件
例如:
SELECT LastName FROM Employees WHERE FirstName = 'John' 上面的语句将从员工表中检索出所有姓名为John的员工的名称 2. DISTINCT子句
DISTINCT 子句可以用于从结果集中筛选出不同的值。
例如,您可以使用该子句返回指定表中特定列的唯一值。
语法:
SELECT DISTINCT列名称 FROM表名称 WHERE 条件
例如:
SELECT DISTINCT LastName FROM Employees WHERE FirstName = 'John'
上面的语句将返回John名字拥有的所有不同的姓氏。
3. ORDER BY 子句
ORDER BY 子句用于按照指定列的升序或降序排列检索出的数据,默认情况下,ORDER BY 子句会按照升序排列数据。
语法:
SELECT列名称 FROM表名称 WHERE 条件 ORDER BY 列名称[ASC | DESC]
例如:
SELECT LastName FROM Employees WHERE FirstName = 'John' ORDER BY LastName DESC
上面的语句将按照John的姓氏的倒序排列数据。
SQL嵌套SELECT语句的用法

SQL嵌套SELECT语句的用法SQL嵌套SELECT语句是很常见的SQL语句,下面就为您详细介绍SQL嵌套SELECT语句的语法,并附相关示例,供您参考学习之用。
嵌套SELECT语句也叫子查询,一个SELECT 语句的查询结果能够作为另一个语句的输入值。
子查询不但能够出现在Where 子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。
1、单行子查询:单行子查询是指子查询的返回结果只有一行数据。
当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。
例:1.select ename,deptno,sal2.from emp3.where deptno=(select deptno from dept whereloc='NEW YORK');2、多行子查询:多行子查询即是子查询的返回结果是多行数据。
当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。
而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。
例:1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字1.sql> select stName2.3.from Student4.5.where stId in(selectdistinct stId from scorewhere teId=(select teId from teacher whereteName='Rona'));查询所有部门编号为A的资料:1.SELECT ename,job,sal2.3.FROM EMP4.5.WHERE deptno in ( SELECT deptno FROM deptWHERE dname LIKE 'A%');2).多行子查询使用ALL操作符号例子:查询有一门以上的成绩高于Kaka的最高成绩的学生的名字:1.sql> select stName2.3.from Student4.5.where stId in(select distinct stId from score where score >all(select score from score where stId=(select stId from Student wherestName= 'Kaka') ));3). 多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Kaka的任何一门成绩的学生的名字:1.sql> select stName2.3.from Student4.5.where stId in(select distinct stId from score where score >any(select score from score where stId=(select stId from Student wherestName='Kaka')));3、多列子查询:当是单行多列的子查询时,主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较;当是多行多列子查询时,主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
实验四SELECT语句的使用

实验四 SELECT语句的使用实验目的:1、掌握SELECT语句的基本语法。
2、了解SELECT语句中各子句的作用和特点。
3、掌握SELECT语句的统计函数的作用和方法。
4、掌握子查询的用法。
5、掌握连接查询的用法。
实验准备:1、熟悉SELECT语句的基本语法格式。
2、了解SELECT语句的执行方法。
3、明确SELECT语句各子句的区别。
实验任务:内容一:SELECT语句的简单查询一、数据需求分析查询是对存储于Microsoft SQL Server 2000中的数据的请求,通过查询用户可以获得所需要的数据。
查询可以通过执行SELECT语句实现。
二、内容要点分析1、SELECT语句的基本语法格式:SELECT 字段列表[ INTO 新表 ]FROM 数据源[ WHERE 搜索条件 ][ GROUP BY 分组表达式 ][ HAVING 搜索表达式 ][ ORDER BY 排序表达式 [ ASC | DESC ] ]说明:SELECT子句:用于指定输出字段(必选)。
INTO子句:用于将查询结果存储到一个新的数据库表中。
FROM子句:用于指定查询的数据来源(必选)。
WHERE子句:用于指定对记录的查询条件。
GROUP BY子句:对查询到的记录进行分组。
HAVING子句:与GROUP BY子句一起使用,指定对分组后的记录的查询条件。
ORDER BY子句:对查询到的记录进行排序。
2、SELECT子句的用法(1)选取全部字段●除了使用“*”号外,还可在SELECT子句后面依次列出各个字段。
(2)选取部分字段●在SELECT子句后依次列出部分字段,并用英文逗号隔开。
(3)为结果集内的列指定别名●原字段名 AS 字段别名●字段别名 = 原字段名(4)消除结果集中取值重复的行●DISTINCT 字段名(加在有重复值的字段前面)(5)显示表中前面若干条记录●TOP N|TOP N PERCENT 字段列表3、WHERE<查询条件> 的用法(1)使用单一查询条件过滤记录(比较大小)<表达式><比较运算符><表达式>(2)确定查询条件范围列表达式 [NOT]BETWEEN 初始值 AND 终止值●范围运算符BETWEEN…AND…和NOT BETWEEN…AND…查询列值在(或不在)指定范围内的记录。
SQL语言中的SELECT语句 实现排序操作的子句

SQL语言中的SELECT语句实现排序操作的子句一、select——从表中检索数据1、distinct——放在列名的前面,检索不同的值2、limit——限制结果limit5→返回不多于5行。
带一个值的limit总是从第一行开始,给出的数为返回的行数;limit5,5返回从行5开始的5行。
第一个数为开始位置,第二个数为要检索的行数;注意:limit1,1检索出的为第二行而不是第一行(检索出来的第一行为行0而不是行1,即表中记录从第0行开始)二、order by子句——排序数据位于FROM子句之后DESC→降序排序,只应用到直接位于其前面的列名;多列降序,必须对每个列指定DESCASC→升序排序(升序是默认的,如果不指定DESC,默认是升序),同DESC备注:order by子句位于FROM子句之后,若使用limit,limit 必须位于order by之后;使用order by和limit的组合,能找出—个列中最高或最低的值。
三、where子句——指定搜索条件过滤数据1、同时使用order by和where子句时,应该让order by位于where之后;2、where子句操作符:=等于;<>不等于;!=不等于;<小于;<=小于等于;>大于;>=大于等于;BETWEEN在制定的两个值之间(与AND搭配)3、逻辑操作符logical operatorAND满足所有给定条件的行;OR检索匹配任一条件的行AND在计算次序中优先级高于OR。
备注:任何时候使用具有AND和OR操作符的where子句,都应该使用圆括号明确地分组操作符(圆括号在计算次序中的优先级高于AND和OR)4、IN操作符IN指定条件范围,范围中的每个条件都可以进行匹配(与OR功能相同)Where VEN did IN(1002.1003)等价于where VEN did=1002ORvendid=1003。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
ü掌握SQL的概念及特点ü掌握SQLserver 的安装方法ü理解SQL中的数据定义ü理解SELECT 语句及其子句Ø关系型数据库标准语言SQL®SQL是Structured Query Language的缩写,即结构化查询语言。
它是关系数据库的标准语言。
查询是SQL语言的重要组成部分,SQL还包含数据定义、数据操作和数据控制功能等内容。
SQL已经成为关系数据库的标准数据语言,所以现在所有的关系数据库管理系统都支持SQL。
掌握SQL语法可以更加灵活地建立查询和视图。
® SQL语言来源于20世纪70年代IBM的一个被称为SEQUEL(Structured English Query Language)的研究项目。
20世纪80年代,SQL由ANSI进行了标准化,它包括了定义和操作数据的指令。
由于它具有功能丰富、使用方式灵活、语言简洁易学等突出特点,在计算机界深受广大用户欢迎,许多数据库生产厂家都相继推出各自支持SQL标准。
1998年4月,ISO提出了具有完整性特征的SQL,并将其定为国际标准,推荐它为标准关系数据库语言。
1990年,我国也颁布了《信息处理系统数据库语言SQL》,将其定为中国国家标准。
®SQL的特点®1. 综合统一®2. 高度非过程化®3. 面向集合的操作方式®4. 以同一种语法结构提供两种使用方法®例语言简洁,易学易用综合统一(操纵三级模式)SQL视图1视图2基表1基表2基表3基表4存储文件1存储文件2外模式模式内模式数据安全数据完整性实例引入:SQL 语句需要在数据库上执行的大部分工作都由 SQL 语句完成。
下面的 SQL 语句,从 "Websites" 表中选取所有记录:解析use RUNOOB; 命令用于选择数据库。
set names utf8; 命令用于设置使用的字符集。
SELECT * FROM Websites; 读取数据表的信息。
上面的表包含五条记录(每一条对应一个网站信息)和5个列(id、name、url、alexa 和country)。
SQL语句可以在命令窗口中执行,也可以作为查询或视图容)被使用,还可以在程序文件被执行。
//一些最重要的 SQL 命令//SELECT - 从数据库中提取数据UPDATE - 更新数据库中的数据DELETE - 从数据库中删除数据INSERT INTO - 向数据库中插入新数据CREATE DATABASE - 创建新数据库ALTER DATABASE - 修改数据库CREATE TABLE - 创建新表ALTER TABLE - 变更(改变)数据库表DROP TABLE - 删除表CREATE INDEX - 创建索引(搜索键)DROP INDEX - 删除索引®数据库中最常见的操作是数据查询,也是SQL的核心。
SQL SELECT 语句SELECT 语句用于从数据库中选取数据。
结果被存储在一个结果表中,称为结果集。
SQL SELECT 语法SELECT column_name,column_name FROM table_name;与SELECT * FROM table_name;®SQL给出了简单而又丰富的查询语句形式,SQL的查询命令也称作SELECT命令,它的基本形式由SELECT-FROM-WHERE查询块组成,多个查询块可以嵌套执行。
®格式:® SELECT [ALL|DISTINCT][ TOP〈表达式〉][〈别名〉]〈Select表达式〉[AS 〈列名〉][, [〈别名〉]〈Select表达式〉[AS 〈列名〉]…]FORM[〈数据库名〉 !]〈表名〉[[AS]Local_Alias][[INNER | LEFT [OUTER] | RIGHT [OUTER] | FULL [OUTER]JOIN[〈数据库名〉!]〈表名〉[[AS]Local_Alias][ON〈联接条件〉]][INTO 〈查询结果〉 |TO FILE 〈文件名〉[ADDITIVE]| TO PRINTER [PROMPT] | TO SCREEN][PREFERENCE PreferenceName][NOCONSOLE][PLAIN][NOWAIT][WHERE 〈联接条件1〉[AND 〈联接条件2〉…][AND | OR 〈筛选条件〉…]][GROUP BY 〈组表达式〉][, 〈组表达式〉…]][HAVING ]〈筛选条件〉][UNION [ALL]〈SELECT命令〉][ORDER BY 〈关键字表达式〉[ASC |DESC][, 〈关键字表达式〉[ASC |DESC]…]]®说明:SELECT-SQL命令的格式包括三个基本子句:SELECT子句、FROM子句、WHERE子句,还包括操作子句:ORDER子句、GROUP子句、UNION子句以及其他一些选项。
An Introduction to Database System<表名>:所要定义的基本表的名字®<列名>:组成该表的各个属性(列)®<列级完整性约束条件>:涉及相应属性列的完整性约束条件®<表级完整性约束条件>:涉及一个或多个属性列的完整性约束条件CREATE TABLE <表名>(<列名> <数据类型>[ <列级完整性约束条件> ][,<列名> <数据类型>[ <列级完整性约束条件>] ] …[,<表级完整性约束条件> ] );®SELECT子句用来指定查询结果中的数据。
其中:®ALL选项:表示选出的记录中包括重复记录,这时缺省值;DISTINCT则表示选出的记录中不包括重复记录。
®TOP〈表达式〉选项:表示在符合条件的记录中,选取指定数量或百分比(〈表达式〉)记录。
[〈别名〉]〈Select表达式〉[AS〈列名〉]选项中的别名是字段所在的表名;〈Select表达式〉,可以是字段名或字段表达式;〈列名〉用于指定输出时使用的列标题,可以不同于字段名。
®〈Select表达式〉用一个*号来表示时,指定所有的字段。
®用于指定查询的表与联接类型。
其中:®JOIN关键字用于联接其左右两个〈表名〉所指定的表。
INNER | LEFT[OUTER] | RIGHT [OUTER] | FULL[OUTER]选项,指定两表联接时的联接类型,联接类型有4种,如表例2所示。
其中的OUTER选项,表示外部联接,即允许满足联接条件的记录,又允许不满足联接条件的记录。
若省略OUTER选项,效果不变。
®用来指定查询的条件。
其中的 〈联接条件〉 指定一个字段,该字段连接FROM子句中的表。
®如果查询中包含不止一个表,就应该为第一个表后的每一个表指定连接条件。
对查询结果按〈组表达式〉值分组,常用于分组统计。
例 HAVING子句当含有GROUP BY子句时,HAVING子句可用作记录查询的限制条件;无GROUP BY 子句时,HAVING子句的作用如同 WHERE子句。
6. ORDER BY子句指定查询结查中记录按〈关键字表达式〉排序,默认升序。
选项ASC表示升序,DESE表示降序。
®UNION子句:可以用UNION子句嵌入另一个SELECT-SQL命令,使这两个命令的查询结果合并输,但输出字段的类型和宽度必须一致。
UNION子句默认组合结果中排除重复行,使用ALL,则允许包含重复行。
®SELECT查询命令的使用非常灵活,用它可以构造各种各样的查询。
本章将通过大量的实例来介绍SELECT命令的使用方法。
简单查询只含有基本子句,可有简单的查询条件。
【例2】在zggz表中,检索实发工资大于2000元的记录。
SELECT 编号,姓名,实发工资FROM zggzWHERE 实发工资>2000【例3】在zgda表中,检索所有职称名称。
SELECT DISTINCT 职称 FROM zgda 【例4】在zgda表中,检索职称是助教的记录。
SELECT 编号,姓名,职称FROM zgdaWHERE 职称="助教"【例5】在zggz表中,检索实发工资小于1000大于1800元的记录。
SELECT 编号,姓名,实发工资FROM zggzWHERE 实发工资>1000 AND 实发工资<1800®在SQL语句中,WHERE子句后面的联接条件,除了可以使用VFP语言中的关系表达式以及逻辑表达外,还可以使用几个特殊运算符:(1)[NOT]IN:表示[不]在…之中。
(2)[NOT]BETWEEN…AND…:表示[不]在…之间。
(3)[NOT]LIKE:表示[不]与…匹配。
下面以实例来说明此用法。
说明:(1)NOT运算符来设计否定条件。
(2)LIKE运算符提供两种字符串匹配方式,一种是使用下划线符号“_”,匹配一个和任意字符,另一种是使用百分号“%”,匹配0个或多个任意字符。
(3)IN运算符,格式为IN(常量1,常量2,…)。
含义为查找和常量相等的值。
【例6】在zgda表中,检索性别是男的记录。
SELECT DISTINCT 编号,姓名,性别 FROM zgda WHERE 性别 LIKE "男"可以使用NOT运算符来设计否定条件,检索性别不是男的记录。
SELECT DISTINCT 编号,姓名,性别FROM zgdaWHERE NOT(性别 LIKE "男")【例7】在zgda表中,检索所有姓刘的记录。
SELECT 编号,姓名FROM zgdaWHERE 姓名 LIKE "刘%"【例8】在zgda表中,检索所有姓陈和姜的记录。
SELECT 编号,姓名FROM zgdaWHERE 姓名 IN("陈","姜")上式可以改为VFP条件,执行结果是一样的。
SELECT 编号,姓名FROM zgdaWHERE 姓名="陈" OR 姓名="姜"2.4 简单的联接查询联接是关系的基本操作之一,联接查询是一种基于多个关系的查询。
【例9】在zgda表和zggz表中,检索实发工资大于2000元的记录。
SELECT zgda.编号,zgda.姓名,zggz.实发工资FROM zgda,zggzWHERE (实发工资>2000) AND (zgda.编号=zggz.编号)zgda.编号=zggz.编号 &&编号是联接的条件2.4 简单的联接查询【例10】在zgda表和zggz表中,检索职称是讲师, 并且实发工资大于1900元的记录SELECT zgda.编号,zgda.姓名,zgda.职称,zggz.实发工资FROM zgda,zggzWHERE (职称="讲师") AND (实发工资>1900)AND (zgda.编号=zggz.编号)2.5 嵌套查询®为了讨论嵌套查询,在此引入一个订货管理数据库,此数据库涉及4个表(4 个关系),即仓库表、职工表、订购单表、供应商表,4个表的内容见教材 P.90。