注册 登录
编程论坛 VFP论坛

工作区?

su0527 发布于 2019-06-22 06:12, 11192 次点击
代码如下:
SELECT * FROM spxx  INTO CURSOR k1
SELECT * FROM xsxx  INTO CURSOR k2
SELECT * FROM jhxx  INTO CURSOR k3
FOR i=1 TO 20
IF !dbf(i)==""
?" 工作区"+ALLTRIM(STR(i))+"-----"+DBF(i)
ENDIF
ENDFOR
输出结果如下:
只有本站会员才能查看附件,请 登录


为什么每张表占用两个工作区?
4 回复
#2
sdta2019-06-22 06:27
第一行前加
CLOSE DATABASES
#3
gs25367856782019-06-22 07:31
(1)在DOS时代,工作区是个重要概念,人们总是
[先要选择指定工作区,然后打开指定表]
select 1
use aa

(2)在WINDIWS时代,人们不再纽结于工作区,总是
[先要选择最低工作区,然后打开指定表,选定指定表]
select 0
use aa
select aa

(3)在你的问题中,执行
SELECT * FROM spxx  INTO CURSOR k1
的时候,表spxx,表k1,都是打开的
至于打开在哪个工作区,一般不去研究
使用时,只要
select spxx 选定spxx表
select k1 选定k1表
。。。
#4
wzxc2019-06-24 22:05
CURSOR 也占一个工作区,只是仍显示基表名。
在数据期窗口,基表显示其在的区,而cursor则不显示。
#5
xuminxz2019-06-26 07:53
SELECT * FROM spxx  INTO CURSOR k1
并没有建立新表,只是给spxx一个新别名。
SELECT * FROM spxx  INTO CURSOR k1 where .t.试试看,结果就不一样了。
1