预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共44页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

vfp中的数据查询vfp中的数据查询(锦集5篇),下面是小编整理过的vfp中的数据查询,欢迎您阅读分享借鉴,希望对您有所帮助。篇1:vfp中的数据查询VisualFoxPro语言体系包括三个部分:一是传统的Xbase语言体系,二是结构化查询语言(SQL),三是面向对象化(OOP)程序设计语言,笔者认为,VisualFoxPro这三部分语言都具有数据查询的功能。可能对于Xbase语言和SQL语言具有数据查询功能大家是没有异议的,但VisualFoxPro中的OOP语言应不会有数据查询功能,因为一般认为在VisualFoxPro中数据处理是非面向对象的,就此可以得出VisualFoxPro中的OOP语言应不具备数据查询功能。其实则不然,当我们在VisualFoxPro中通过OOP语言导入当前流行的RDO或ADO数据处理模型时,我们就会得出不同的答案。本文想集中精力讨论VisualFoxPro中有关Xbase语言和SQL语言的数据查询方法。在我们开始之前,先让我们分清Xbase语言和SQL语言在数据查询中扮演的不同角色。一句话:SQL语言侧重用于批量数据查询及复杂的关系型操作。由于篇幅关系我们不可能在此详细讲述SELECT—SQL语句的所有内容。读者有兴趣可以参看本站推出的《结构化的查询语言(SQL)》。作为优秀的数据处理语言(DML),Xbase中许多命令、函数有数据查询功能,我们可以讲Browse、List这样的命令也能查找数据,但这在数据库系统开发中有多大作用?所以我们不讨论它们。首先,我们通过以下命令营建一个Demo环境。要求:查找COL1=9023时COL2的值。CLOSEALLCREATETABLEABC(COL1I,COL2I)FORI=1TO10000?INSERTINTOABC(COL1,COL2)VALUES(I,RAND*100000)ENDFORINDEXONCOL1TAGCOL1USE使用LOCATE命令USEABCLOCATEFORCOL1=9023IIF(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命令USEABCSEEK9023ORDERTAGCOL1IIF(FOUND(),MESSAGEBOX(“COL2=”+STR(COL2)),MESSAGEBOX(“没有找到”))USE使用SEEK()函数USEABCIIF(SEEK(9023,“ABC”,“COL1”),MESSAGEBOX(“COL2=”+STR(COL2)),;MESSAGEBOX(“没有找到”))USE使用LOOKUP()函数USEABCIIF(EMPTY(LOOKUP(COL2,9023,COL1,COL1)),MESSAGEBOX(“没有找到”),;MESSAGEBOX(“COL2=”+STR(COL2)))USE使用INDEXSEEK()函数USEABCIIF(INDEXSEEK(9023,.T.,“ABC”,“COL1”),MESSAGEBOX(“COL2=”+STR(COL2)),;MESSAGEBOX(“没有找到”))USE以上高速查询语句有着共同的特点,就是必须使用索引,高速查询之所以能称为高速其原因就是使用了索引技术,我们在查看命令手册时,会发现“不能采用RUSHMORE优化技术”的字句。您也许要问:RUSHMORE技术可以提高查询速度,这些语句不能享用它,速度何来?我们在前文已经指出RUSHMORE技术的本质是索引,是对那些不享用索引技术的条件语句进行索引优化,使其能利用索引技术带来的高效率。有既然高速查询语句天生建立在索引技术之上,他们就没有必要进行RUSHMORE优化。关于以上语句的具体用法由于篇幅关系不能展开,这里就简要介绍一下INDEXSEEK()函数吧!INDEXSEEK()是VisualFoxPro6.0中新添的函数,属于Xbase语言范畴。笔者