vfp中的数据查询

Visual FoxPro 语言体系包括三个部分:一是传统的Xbase 语言体系,二是结构化查询语言(SQL),三是面向对象化(OOP)程序设计语言。笔者认为,Visual FoxPro 这三部分语言都具有数据查询的功能。可能对于Xbase语言和SQL语言具有数据查询功能大家是没有异议的,但Visual FoxPro中的OOP语言应不会有数据查询功能,因为一般认为在Visual FoxPro中数据处理是非面向对象的,就此可以得出Visual FoxPro中的OOP语言应不具备数据查询功能。其实则不然,当我们在Visual FoxPro中通过OOP语言导入当前流行的RDO或ADO数据处理模型时,我们就会得出不同的答案。

本文想集中精力讨论Visual FoxPro 中有关Xbase语言和SQL语言的数据查询方法。在我们开始之前,先让我们分清Xbase语言和SQL语言在数据查询中扮演的不同角色。一句话:SQL语言侧重用于批量数据查询及复杂的关系型操作。

由于篇幅关系我们不可能在此详细讲述SELECT—SQL 语句的所有内容。读者有兴趣可以参看本站推出的《结构化的查询语言(SQL)》。

作为优秀的数据处理语言(DML),Xbase 中许多命令、函数有数据查询功能,我们可以讲Browse、List这样的命令也能查找数据,但这在数据库系统开发中有多大作用?所以我们不讨论它们。

首先,我们通过以下命令营建一个Demo环境。要求:查找COL1=9023时COL2的值。

CLOSE ALL
CREATE TABLE ABC (COL1 I, COL2 I)
FOR I=1 TO 10000?
INSERT INTO ABC (COL1, COL2) VALUES (I, RAND()*100000)
ENDFOR
INDEX ON COL1 TAG COL1
USE

使用LOCATE 命令

USE ABC
LOCATE FOR COL1=9023
IIF(FOUND(),MESSAGEBOX("COL2="+STR(COL2)),MESSAGEBOX("没有找到"))
USE

笔者认为:LOCATE命令速度很慢,就上例来说记录指针运动了9022次,如果我有1亿条记录呢?为了解决这类问题,FoxPro提出了RUSHMORE技术用于优化FOR 子句,但其本质仍是索引技术。说句实话初、中级用户一般是没有能力优化FOR 子句的,我们建议大家使用一些高速查询语句,如:SEEK命令,SEEK()、LOOKUP()、INDEXSEEK()函数。在我们讨论这些高速查询语句前,我还想讲一下CONTINUE命令与LOCATE命令的联合使用。在SELECT-SQL没有被引入Xbase语言体系前,我们只能用LOCATE+CONTINUE进行批量数据查询,我想现在大家一定都使用SELECT-SQL进行批量数据检索了,如果这样您会发现以前的多行代码被一句SELECT-SQL命令取代。

使用SEEK命令

USE ABC
SEEK 9023 ORDER TAG COL1
IIF(FOUND(),MESSAGEBOX("COL2="+STR(COL2)),MESSAGEBOX("没有找到"))
USE

使用SEEK()函数

USE ABC
IIF(SEEK(9023,"ABC","COL1"),MESSAGEBOX("COL2="+STR(COL2)),;
MESSAGEBOX("没有找到"))
USE

使用LOOKUP()函数

USE ABC
IIF(EMPTY(LOOKUP(COL2,9023,COL1,COL1)),MESSAGEBOX("没有找到"),;
MESSAGEBOX("COL2="+STR(COL2)))
USE

使用INDEXSEEK()函数

USE ABC
IIF(INDEXSEEK(9023,.T.,"ABC","COL1"),MESSAGEBOX("COL2="+STR(COL2)),;
MESSAGEBOX("没有找到"))
USE

以上高速查询语句有着共同的特点,就是必须使用索引,高速查询之所以能称为高速其原因就是使用了索引技术。我们在查看命令手册时,会发现“不能采用RUSHMORE 优化技术”的字句。您也许要问:RUSHMORE技术可以提高查询速度,这些语句不能享用它,速度何来?我们在前文已经指出RUSHMORE技术的本质是索引,是对那些不享用索引技术的条件语句进行索引优化,使其能利用索引技术带来的高效率。有既然高速查询语句天生建立在索引技术之上,他们就没有必要进行RUSHMORE优化。

关于以上语句的具体用法由于篇幅关系不能展开,这里就简要介绍一下INDEXSEEK()函数吧!

INDEXSEEK()是Visual FoxPro 6.0中新添的函数,属于Xbase语言范畴。笔者以为用好它,就可以忘记其他高速查询语句了。

INDEXSEEK(eExpression,1MovePointer,cTableAlias,cTagName)

  1. 参数eExpression表示要搜索索引关键字表达式。
  2. 参数1MovePointer=.t.时,表示找到有关记录后指针移动到匹配记录,没有找到不移动指针,这与Seek()函数相似。1MovePointer=.f.时,表示即使找到有关记录也不移动记录指针,这样就可以大大提高查询效率,当然如果要求得到目标行有关字段的信息,这个好处就不可享用了。
  3. 参数cTableAlias表示表的别名。
  4. 参数cTagName表示索引标示。

使用SQL-Select语句

SELECT COL2 FROM ABC WHERE COL1=19023 INTO ARRAY SZ
USE IN ABC
IIF(_TALLY<>0,MESSAGEBOX("COL2="+STR(SZ)),MESSAGEBOX("没有找到"))

时间: 2025-01-31 01:26:45

vfp中的数据查询的相关文章

基于SQL中的数据查询语句汇总

以下是对SQL中的数据查询语句进行了汇总介绍,需要的朋友可以过来参考下   where条件表达式 --统计函数 复制代码 代码如下: Select count(1) from student; --like模糊查询 --统计班上姓张的人数 复制代码 代码如下: select count(*) from student where realName like '张%'; --统计班上张姓两个字的人数 复制代码 代码如下: select count(*) from student where rea

ORACLE和SYBASE数据库中实现数据查询条数限制的SQL语句实现

一.概述 对于某些需要通过数据库与大量数据打交道的软件来说,处理性能相当的重要.为了保证软件能够将所有数据处理完而不至于崩溃,分批处理的思想应运而生.分批处理的具体做法是编写SQL语句,每次返回规定条数的数据给软件处理,待这一批数据处理完之后,再接着处理下一批. 本文通过对具体的数据库表(tb_employeeinfo)的操作过程,展示了ORACLE和SYBASE数据库中分批处理SQL语句的编写方法. 二.ORACLE数据库中的处理 首先,建立tb_employeeinfo表,其定义如下: be

SQL Server 中时间数据查询需要注意的一个小问题

server|数据|问题 由于本人的工作环境,接触到基于不同语言下的SQL Server,遇到不少麻烦,其中DateTime数据类最多,中文,韩文等数据库中时间的默认格式为:MM/DD/YY 或 YY/MM/DD但英文中又分为:MM/DD/YY 或 DD/MM/YY 这样问题就来啦例如: 我的一个韩国客户,操作系统:windows 2000 server 英文版,MS SQL Server 韩文版他的主机在新西兰,时间系统默认为新西兰 DD/MM/YY数据库时间默认为:  MM/DD/YY当数据

基于SQL中的数据查询语句汇总_Mysql

where条件表达式--统计函数 复制代码 代码如下: Select count(1) from student; --like模糊查询--统计班上姓张的人数 复制代码 代码如下: select count(*) from student where realName like '张%'; --统计班上张姓两个字的人数 复制代码 代码如下: select count(*) from student where realName like '张_'; --统计班上杭州籍的学生人数 复制代码 代码如

通过下拉列表中的项来查询数据库中的数据

问题描述 通过下拉列表中的项来查询数据库中的数据 想通过图片中的下拉列表中的各项来确定为查询条件,再输入关键字来从数据库中进行数据查询,请问各位大神应该怎么做,最好详细点..谢谢 解决方案 第一步:获取下拉框中的值,参考网站:http://blog.csdn.net/qq_19558705/article/details/49893435 第二步:通过ajax把获取的值传给后台, 参考网站:http://blog.csdn.net/qq_19558705/article/details/4992

数据查询--SELECT语句

   数据库是为更方便有效地管理信息而存在的人们,希望数据库可以随时提供所需要的数据信息.因此,对用户来说,数据查询是数据库最重要的功能.本章将讲述数据查询的实现方法. 在数据库中,数据查询是通过SELECT 语句来完成的.SELECT 语句可以从数据库中按用户要求检索数据,并将查询结果以表格的形式返回.我们在"Transact-SQL 语言"章节及前面的章节中已经初步接触到了SELECT 语句的一些用法,在本章中将分类讲述其具体用法. 本节讲述SELECT 语句完整的锓ń峁梗馐且桓

跟我学SQL:(一)数据查询

数据  且不说你是否正在从事编程方面的工作或者不打算学习SQL,可事实上几乎每一位开发者最终都会遭遇它.你多半还用不着负责创建和维持某个数据库,但你怎么着也该知道以下的一些有关的SQL知识.     我为那些感兴趣的开发者或者能从数据库操作中得益的读者撰写了这篇关于基本SQL语法的概述性文章.本文主要讨论基本的数据操作查询,后续的文章还会继续讨论如何修改数据库自身以及更高级的查询概念. SQL数据库是怎么回事?  SQL(结构化查询语言)就是负责与ANSI维护的数据库交互的标准.最新的版本是SQ

MS SQL基础教程:数据查询-SELECT语句

数据库是为更方便有效地管理信息而存在的人们,希望数据库可以随时提供所需要的数据信息.因此,对用户来说,数据查询是数据 库最重要的功能.本章将讲述数据查询的实现方法. 在数据库中,数据查询是通过SELECT 语句来完成的.SELECT 语句可以从数据库中按用户要求检索数据,并将查询结果以表格的形式返回.我们在"Transact-SQL 语言"章节及前面的章节中已经初步接触到了SELECT 语句的一些用法,在本章中将分类讲述其具体用法. 本节讲述SELECT 语句完整的语法结构,这是一个非

看实例学VFP:删除数据表中的记录

本例对看实例学VFP:对数据表中记录进行修改一文的实例进行了一点改进,增加了"撤消"功能.程序运行时如下图: 在组合框中选择要查找的字段,在文本框中输入查找内容后单击右侧的"查找"按钮后将查找结果显示在上方的表格中,"查找"按钮变成"撤消"按钮,同时激活"删除"按钮及用于显示数据的文本框,并将当前记录(满足查询条件的记录)的值同时显示在文本框中,:单击"删除"按钮后会删除查找出来的记录刷