| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 599 人关注过本帖
标题:索引查询问题,急!
只看楼主 加入收藏
dhjyy
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-1-22
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:4 
索引查询问题,急!
小弟有一个数据库,记录共有3102575条记录,经常使用SELECT-SQL查询根据某个条件提取出自己想要的数据,问题是用SELECT-SQL查询速度太慢,我想用索引查询的方式查询,结果弄了半天,只能查询出2条记录,太郁闷了,请高手为我看看程序不知道哪里不对,
SET TALK OFF
SET SAFETY off
CLOSE ALL
SELECT 1
USE 2009 ORDER hm
SELECT 2
 USE kk
 ZAP
 SELECT 1
  seek "江于友"     
     IF  FOUND()
      jyrqzd=ALLTRIM(jyrq)
      jgmzd=ALLTRIM(jgm)
      dljgzd=ALLTRIM(dljg)
      jymzd=ALLTRIM(jym)
      zyzd=ALLTRIM(zy)
      zhzd=ALLTRIM(zh)
      hmzd=ALLTRIM(hm)
      bzzd=ALLTRIM(bz)
      kmhzd=ALLTRIM(kmh)
      dfkmzd=ALLTRIM(dfkm)
      jyjezd=jyje
      yezd=ye
      czyzd=ALLTRIM(czy)
      fhyzd=ALLTRIM(fhy)
      zxlshzd=ALLTRIM(zxlsh)     
  SELECT 2
  APPEND blank
  replace jyrq WITH jyrqzd,jgm WITH jgmzd,dljg WITH dljgzd, jym WITH jymzd,zy WITH zyzd,zh WITH zhzd,hm WITH hmzd,bz WITH  bzzd,kmh WITH kmhzd,dfkm WITH dfkmzd,jyje WITH jyjezd,;
          ye WITH yezd,czy WITH czyzd,fhy WITH fhyzd,zxlsh WITH zxlshzd   
  ENDIF  
  SELECT 1
  DO WHILE NOT EOF()
   SKIP  
      IF FOUND()
      jyrqzd=ALLTRIM(jyrq)
      jgmzd=ALLTRIM(jgm)
      dljgzd=ALLTRIM(dljg)
      jymzd=ALLTRIM(jym)
      zyzd=ALLTRIM(zy)
      zhzd=ALLTRIM(zh)
      hmzd=ALLTRIM(hm)
      bzzd=ALLTRIM(bz)
      kmhzd=ALLTRIM(kmh)
      dfkmzd=ALLTRIM(dfkm)
      jyjezd=jyje
      yezd=ye
      czyzd=ALLTRIM(czy)
      fhyzd=ALLTRIM(fhy)
      zxlshzd=ALLTRIM(zxlsh)     
  SELECT 2
  APPEND blank
  replace jyrq WITH jyrqzd,jgm WITH jgmzd,dljg WITH dljgzd, jym WITH jymzd,zy WITH zyzd,zh WITH zhzd,hm WITH hmzd,bz WITH  bzzd,kmh WITH kmhzd,dfkm WITH dfkmzd,jyje WITH jyjezd,;
          ye WITH yezd,czy WITH czyzd,fhy WITH fhyzd,zxlsh WITH zxlshzd     
 ENDIF
ENDDO
CLOSE ALL
USE kk
  COPY TO c:\init\江于友 TYPE xls
=MESSAGEBOX("处理完毕!!")
CLOSE ALL
小弟在此先谢谢了!
搜索更多相关主题的帖子: 索引 查询 
2010-05-09 23:11
茵梦湖
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:31
帖 子:545
专家分:2180
注 册:2009-4-25
收藏
得分:16 
很简单的, 不需要1楼这么一长串的代码的~   假设江于友所在字段名为: xxxx, 则代码如下:

clos all
use 2009 ORDER hm
seek "江于友"     
IF  FOUND()
    COPY rest whil xxxx="江于友" TO c:\init\江于友 TYPE xls
    =MESSAGEBOX("处理完毕!!")
endif
clos all

2010-05-09 23:35
dhjyy
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-1-22
收藏
得分:0 
啊,版主茵梦湖真厉害,问题解决了,版主就是版主!向版主茵梦湖学习!
2010-05-09 23:42
qjbzjp
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:尧的故乡
等 级:贵宾
威 望:48
帖 子:1914
专家分:4397
注 册:2007-3-14
收藏
得分:2 
试试seek命令和locat命令哪个更快:
LOCATE for 姓名="江于友"
IF FOUND()
    COPY TO s:\mydbf xls for 姓名="江于友"
    =MESSAGEBOX("处理完毕!!")
ENDIF

相互学习,互相交流,共同提高。
2010-05-10 09:21
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:2 
当然SEEK啦!二楼的效率是很高的!

★★★★★为人民服务★★★★★
2010-05-10 11:14
快速回复:索引查询问题,急!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.058529 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved