问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

VFP SQL语句求解

发布网友 发布时间:2022-04-13 13:21

我来回答

3个回答

热心网友 时间:2022-04-13 14:50

从一个或多个表中检索数据。SELECT SQL 命令是与其它 Visual FoxPro 一样的内置的 Visual FoxPro 命令。当你使用 SELECT 来生成查询时, Visual FoxPro 翻译查询并从表中获取指定数据。你可以从以下地方创建 SELECT 查询:
“命令”窗口中
带有其它任何 Visual FoxPro 命令的 Visual FoxPro 程序中
查询设计器中
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] SELECTCommand]
[Order By Order_Item [ASC | DESC] [, Order_Item [ASC | DESC] ...]]
参数
SELECT
在 SELECT 子句中指定在查询结果中包含的字段、常量和表达式。
ALL
查询结果中包含所有行 ( 包括重复值 )。ALL 是默认设置。
DISTINCT
在查询结果中剔除重复的行。每一个 SELECT 子句只能使用一次 DISTINCT。
TOP nExpr [PERCENT]
在符合查询条件的所有记录中,选取指定数量或百分比的记录。TOP 子句必须与 ORDER BY 子句同时使用。ORDER BY 子句指定查询结果中包含的列上由Top字句决定的行数, TOP 子句根据此排序选定最开始的 nExpr个或 nExpr% 的记录。
您可以指定选取 1 到 32767 个记录。使用 ORDER BY 子句指定的字段进行排序,会产生并列的情况,比如,可能有多个记录,它们在选定的字段上相同;所以,如果您指定 nExpr 为 10,在查询结果中可能多于 10 个记录,因为可能有几个记录位置并列。
如果包含 PERCENT 关键字指定查询结果中的记录数,得到记录数的可能是小数,这时进行取整。包含 PERCENT 关键字时,nExpr 的范围是 0.01 到 99.99。
[Alias.] Select_Item
限定匹配项的名称。Select_Item 指定的每一项在查询结果中都生成一列。一个项可以是以下一个
FROM 子句所包含的表中的字段名称。
一个常量,查询结果中每一行都出现这个常量值。
一个表达式,可以是用户自定义函数名。
关于使用用户定义函数的详细信息, 参见注释节中的带用户定义函数的 SELECT。
你用 Select_Item 指定的各项生成一个查询结果列。
如果两个或更多的项具有相同的名称, 在项名前包含表别名和一个句点来避免列重复。
[AS] Column_Name
为查询输出中的列指定显示名。Column_Name 可以是表达式但不能包含不允许的字符, 如, 字段名中的空格。
当 Select_Item 是一个表达式或包含一个字段函数而且你想给该列一个有意义的名字时该选项是有用的。
FROM [FORCE] DatabaseName!
列出所有从中检索数据的表。
FORCE 指定连接表时按它们出现在 FROM 子句中的顺序。如果省略 FORCE, Visual FoxPro 会试图对查询进行优化。但是, 使用 FORCE 子句,避免了优化过程,可能加快查询执行的速度。
当包含表的数据库不是当前数据库时,DatabaseName! 指定这个数据库的名称。如果数据库不是当前数据库,就必须指定包含表的数据库名称。应在数据库名称之后表名之前加上感叹号(!)分隔符。
[[AS] Local_Alias]
为 Table 中的表指定一个临时名称。如果指定了本地别名,那么在整个SELECT 语句中必须都用这个别名代替表名。本地别名不影响 Visual FoxPro环境。INNER JOIN 只有在其他表中包含对应记录(一个或多个)的记录才出现在查询结果中。
INNER JOIN 只有在其他表中包含对应记录(一个或多个)的记录才出现在查询结果中。
LEFT [OUTER] JOIN 在查询结果中包含:JOIN 左侧表中的所有记录,以及JOIN 右侧表中匹配的记录。OUTER 关键字可被省略;包含 OUTER 强调这是一个外连接 (outer join)。
RIGHT [OUTER] JOIN 在查询结果中包含:JOIN 右侧表中的所有记录,以及 JOIN 左侧表中匹配的记录。OUTER 关键字可被省略;包含 OUTER 强调这是一个外连接接 (outer join)。
FULL [OUTER] JOIN 在查询结果中包含:JOIN 两侧所有的匹配记录,和不匹配的记录;包含 OUTER 强调这是一个外连接 (outer join)。
关于连接的详细信息, 参见备注段中的 Joins。
ON JoinCondition 指定连接条件。
INTO Destination
指定在何处保存查询结果。Destination 可以是下列子句之一:
ARRAY ArrayName ,将查询结果保存到变量数组中。
如果查询结果中不包含任何记录,则不创建这个数组。
CURSOR CursorName [NOFILTER | READWRITE] 将查询结果保存到临时表中。
要创建一个查用于子查询中的游标, 用 NOFILTER。关于 NOFILTER 的详细信息, 参见备注节。
要指定游标是临时的和可修改的, 使用 READWRITE。如果源表或表使用 autoincrementing, 该设置不会被 READWRITE 游标继承。
DBF | TABLE TableName [DATABASE DatabaseName [NAME LongTableName]] 保存查询结果到一个表中。
包含 DATABASE DatabaseName 以指定添加了表的数据库。
包含 NAME LongTableName 可以为该表命一个最多可包括 128 个字符的并且可以在数据库中代替短名字的长名。
如果没有包括 INTO 子句, 查询结果显示在一个“浏览”窗口中。也可以用 TO FILE 子句来定向查询结果到打印机或一个文件。
TO FILE FileName [ADDITIVE] | TO PRINTER [PROMPT] | TO SCREEN
定向查询结果到打印机或一个文件。
ADDITIVE 添加查询输出到 TO FILE FileName 中指定的已存在的文本文件内容中。
TO PRINTER 定向查询输出到一个打印机。在打印开始之前,使用可选的 PROMPT 子句显示一个对话框。您可以根据当前安装的打印机驱动程序调整打印机的设置。将 PROMPT 子句放置在紧跟 TO PRINTER 之后。
TO SCREEN 使查询结果定向输出到 Visual FoxPro 主窗口或活动的用户自定义窗口中。
PREFERENCE PreferenceName
如果查询结果送往浏览窗口,就可以使用 PREFERENCE 保存浏览窗口的属性和选项以备后用。关于 PREFERENCE 功能的详细信息, 参见备注节。
NOCONSOLE
不显示送到文件、打印机或 Visual FoxPro 主窗口的查询结果。
PLAIN
防止列标题出现在显示的查询结果中。不管有无 TO 子句都可使用 PLAIN子句。如果 SELECT 语句中包括 INTO 子句,则忽略 PLAIN 子句。
NOWAIT
打开浏览窗口并将查询结果输出到这个窗口后继续程序的执行。程序并不等待关闭浏览窗口,而是立即执行紧接在 SELECT 语句后面的程序行。关于如何使用 NOWAIT 的说明, 参见备注节。
WHERE JoinCondition
指定 Visual FoxPro 的查询结果中只包括符合指定条件的记录。JoinCondition 指定位于 FROM 子句中的字段连接表。关于指定连接条件的详细信息, 参见备注节。
WHERE 支持 JoinCondition 的 ESCAPE 操作符, 让你可以执行包含有百分号 (%) 和下划线 (_) 通配符的 SELECT SQL 命令查询。ESCAPE 允许你指定一个按原字样处理的 SELECT SQL 命令通配符。在 ESCAPE 子句中, 一旦一个字符被放到通配符字符之前,就表示这个通配符被看作一个文字字符。
FilterCondition
指定将包含在查询结果中记录必须符合的条件。使用 AND 或 OR 操作符,您可以包含随意数目的过滤条件。您还可以使用 NOT 操作符将逻辑表达式的值取反,或使用 EMPTY() 函数以检查空字段。
SELECT SQL 命令在筛选条件中支持 "<field> IS / IS NOT NULL"。要学习如何使用 FilterCondition, 参见示例节。
Group By GroupColumn [, GroupColumn ...]
按列的值对查询结果的行进行分组。GroupColumn 可以是常规的表字段名,也可以是一个包含 SQL 字段函数的字段名,还可以是一个数值表达式,指定查询结果表中的列位置(最左边的列编号为 1 )。
HAVING FilterCondition
指定包括在查询结果中的组必须满足的筛选条件。HAVING 应该同 GROUP BY一起使用。它能包含数量不限的筛选条件,筛选条件用 AND 或 OR 连接,还可以使用 NOT 来对逻辑表达式求反。可以在 HAVING 子句中使用本地别名和字段函数。 关于你可以使用的字段函数的详细信息, 参见备注节。FilterCondition 不能包含子查询。
可以使用带 HAVING 子句的 Group By。使用 HAVING 子句的命令如果没有使用 GROUP BY 子句,则它的作用与WHERE 子句相同。如果 HAVING 子句不包含字段函数的话,使用 WHERE 子句可以获得较快的速度。
HAVING 子句应该出现在 INTO 子句前否则产生错误。
[UNION [ALL] SELECTCommand]
把一个 SELECT 语句的最后查询结果同另一个 SELECT 语句最后查询结果组合起来。默认情况下,UNION 检查组合的结果并排除重复的行。要组合多个UNION 子句,可使用括号。可以用 UNION 子句模拟一个外部联接。
ALL 防止 UNION 删除组合结果中重复的行。
当一个列是备注或通用型时, 不允许连接不同类型的列。
在 Visual FoxPro 8.0 以前的版本中, 当在两个不同类型的字段上执行 UNION 操作时你需要执行明确的转换。Visual FoxPro 现在对支持它的数据类型支持隐含数据类型转换。关于隐含数据类型转换和数据类型优先, UNION 子句允许的规则, 以及其它信息的详细内容, 参见备注节中的数据类型转换和优先。
Order By Order_Item [ASC | DESC]
根据列的数据对查询结果进行排序。每个 Order_Item 都必须对应查询结果中的一列。它可以是下列之一:
FROM 子句中表的字段,同时也是 SELECT 主句(不在子查询中)的一个选择项。
一个数值表达式,表示查询结果中列的位置(最左边列编号为 1 )。
ASC 指定查询结果根据排序项以升序排列。它是 ORDER BY 的默认选项。
DESC 指定查询结果以降序排列。
示例
下例说明 FilterCondition 参数可以使用多种格式:
示例 1
示例 1 以 FieldName1 Comparison FieldName2 格式显示 FilterCondition:
customer.cust_id = orders.cust_id
示例 2
示例 2 以 FieldName Comparison Expression 格式显示 FilterCondition:
payments.amount >= 1000
示例 3
示例 3 以 FieldName Comparison ALL (Subquery) 格式显示 FilterCondition。当筛选条件包括 ALL 时, 在记录被包含进查询结果前, 字段的所有值必须符合由子查询生成的比较条件。
company < ALL (SELECT company FROM customer WHERE country = "UK")
示例 4
示例 4 以 FieldName Comparison ANY | SOME (Subquery) 格式显示 FilterCondition。当筛选条件包括 ANY 或 SOME 时, 字符至少有一个值必须符合由子查询生成的比较条件。
company < ANY (SELECT company FROM customer WHERE country = "UK")
示例 5
示例 5 以 FieldName [NOT] BETWEEN Start_Range AND End_Range 格式显示 FilterCondition。该示例检查是否字段值在指定的范围内。
customer.postalcode BETWEEN 90000 AND 99999
示例 6
示例 6 以 [NOT] EXISTS (Subquery) 格式显示 FilterCondition。该示例检查是否至少有一个行符合子查询的条件。当筛选条件包括 EXISTS 时, 筛选条件求值为真 (.T.) 除非子查询求值为一个空集。
EXISTS ;
(SELECT * FROM orders WHERE customer.postalcode = orders.postalcode)
示例 7
示例 7 以 FieldName [NOT] IN Value_Set 格式显示 FilterCondition。当筛选条件包括 IN 时, 在字段进入查询结果前, 字段必须包含一个值.
customer.postalcode NOT IN ("98052","98072","98034")
注意 在值集合中最多可以包括 24 个项。如果集合中包含了过多的项, SELECT-SQL 语句将因结果太复杂而失败。
示例 8
示例 8 以FieldName [NOT] IN (Subquery) 格式显示 FilterCondition。这里, 在记录出现在查询结果中之前字段必须包含一个由子查询返回的值。
customer.cust_id IN ;
(SELECT orders.cust_id FROM orders WHERE orders.city="Seattle")
示例 9
示例 9 以 FieldName [NOT] LIKE cExpression 格式显示 FilterCondition。
customer.country NOT LIKE "UK"
这些筛选条件搜索匹配 cExpression 的各字段。可以用百分号 (%) 和下划线 (_) 通配符作为 cExpression 的一部分。百分号代表串中任何长度的不知道的字符。下划线代表串中的单个的不知道的字符。
以下示例说明如何在 SELECT SQL 命令中使用用户定义函数:
示例 1
示例 1 显示了 customer 表中所有的公司名称(来自一个表的一个字段)。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT customer.company ;
FROM customer
示例 2
示例 2 显示两个表中的三个字段的内容并根据 cust_id 字段连接表。它使用两个表的本地别名。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT x.company, y.order_date, y.shipped_on ;
FROM customer x
INNER JOIN orders y ON x.cust_id = y.cust_id
示例 3
示例 3 显示了在指定字段只有唯一数据的记录。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT DISTINCT x.company, y.order_date, y.shipped_on ;
FROM customer x, orders y ;
WHERE x.cust_id = y.cust_id
示例 4
示例 4 以升序次序显示了 country、postalcode 和 company 字段。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT country, postalcode, company ;
FROM customer ;
Order By country, postalcode, company
示例 5
示例 5 将来自两个表的字段内容存储在第三个表中。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT x.company, y.order_date, y.shipped_on ;
FROM customer x, orders y ;
WHERE x.cust_id = y.cust_id ;
INTO TABLE custship.dbf
BROWSE
示例 6
示例 6 显示订单 (order) 日期早于 1994 年 2 月 16 日的记录。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT x.company, y.order_date, y.shipped_on ;
FROM customer x, orders y ;
WHERE x.cust_id = y.cust_id ;
AND y.order_date < {^1994-02-16}
示例 7
示例 7 显示订货日期早于 02/16/1994 的所有客户。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT x.company, y.order_date, y.shipped_on ;
FROM customer x
LEFT JOIN orders y ;
ON x.cust_id = y.cust_id
AND y.order_date < {^1994-02-16}
示例 8
示例 8 显示 customer 表中邮政编码与 orders 表的邮政编码相匹配的所有公司名。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT company FROM customer x WHERE ;
EXISTS (SELECT * FROM orders y WHERE x.postalcode = y.postalcode)
示例 9
示例 9 显示 customer 表中公司名以大写的 C 开头,但长度未定的所有记录。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT * FROM customer x WHERE x.company LIKE "C%"
示例 10
示例 10 显示 customer 表中国家名以大写的 U 开头其后跟着未知字母的所有记录。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT * FROM customer x WHERE x.country LIKE "U_"
示例 11
示例 11 以大写方式,输出列为 citylist 显示所有城市名。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT UPPER(city) AS CityList FROM customer
示例 12
示例 12 演示了您可以执行在包含百分比符号 (%) 数据上查询的方式。在百分比之前放置的反斜线 (\) 表示应该将百分比符号当作字符处理,而 ESCAPE 子句中的反斜线指定为转义字符。
因为在 Visual FoxPro 的示例表中不包含百分比符号,所以查询没有返回结果。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT * FROM customer;
WHERE company LIKE "%\%%" ESCAPE "\"
示例 13
示例 13 演示了您可以执行在包含下划线符号 (_) 数据上查询的方式。在下划线之前放置的反斜线 (\) 表示应该将下划线符号当作字符处理,而 ESCAPE 子句中的反斜线指定为转义字符。
因为在 Visual FoxPro 的示例表中不包含下划线符号,所以查询没有返回结果。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT * FROM customer;
WHERE company LIKE "%\_%" ESCAPE "\"
示例 14
在示例 14 中,转义字符使用它自身的含义。短划线既是转义字符同时也是具有意义字符。查询返回公司名包含百分号后跟着短划线的所有行。
因为在 Visual FoxPro 的示例表中不包含百分比符号,所以查询没有返回结果。
CLOSE ALL
CLOSE DATABASES
OPEN DATABASE (HOME(2) + 'data\testdata')
SELECT * FROM customer;
WHERE company LIKE "%-%--%" Escape "-"

热心网友 时间:2022-04-13 16:08

你的sql语句呢????、

热心网友 时间:2022-04-13 17:43

你的问题可以具体一些吗?
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
为什么来大姨妈胸会胀 少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... iphone12冲着电时开着微信忘拉到后台自动锁屏了,这样会对电池有什么影响吗?也没有发热_百度问一问 注销之后还能恢复么?如果能恢复需要通过什么途径恢 山药炸豆付粉的做法 焗山药香甜美味,焗山药要用到什么食材? 注销了能恢复吗 被注销怎么找回来? 注销的怎么找回来? 注销了能恢复吗 不小心注销了怎么恢复? 求32位win7系统下的cad2010能用的tssd2011破解版,跪谢! AutoCAD 2010破解版,64位的win7系统旗舰版,附带序列号密 求一个支持CAD2010的破解版CASS软件,win7,32位系统 求一份win7旗舰版64位的CAD,2010的破解版,谢谢 - 信息提示 外贸业务中银行汇票用的多还是商业汇票? 银行汇票是不是逆汇? 用不用卖方去银行开? 请问从哪下载cad2010破解版 win7系统64位能用的 托收根据所使用的汇票不同,可分为 求cad2010中文破解版win7的 防沉迷要是绑错了能改不 托收与信用证的汇票的区别 请问大佬有超级便签 V1.0 官方安装版软件免费百度云资源吗 超级便签怎么样 E人E本超级便签中删除的录音如何恢复? e人e本t7的相关新闻 e人e本t7的E人E本T7 貂皮大衣能把拉锁改成扣子的吗? 这种衣服可以把纽扣得改成拉链得吗? 羊剪绒大衣扣子之间漏风想改拉链好改吗?还有比别的办法吗? 貂皮大衣肥了想调纽扣位置怎么调? 急!!!哪里可以将大衣纽扣改成牛角扣 纽扣的衣服可以改拉链吗 貂皮扣子改拉链能肥一点吗? 羊绒大衣瘦了,移动纽扣,那扣眼怎么处理? 怎样把照片粘贴到excel表格中 怎样把照片粘贴到excel表格里? USB2.0 SHARING SWITCH怎么使用 usb2.0 sharing switch是什么意思意思 使用usb sharing switch共享打印机,切换后该软件状态不更新,导致打印机状态也不更新。 我两台电脑使用usb sharing switch共享打印机,但是现在不能用了,打印任务有,但是不执行 switch共享账号靠谱吗