标题:请教大家一些关于工作区的问题?
只看楼主
liyuce
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2015-12-14
结帖率:66.67%
已结贴  问题点数:20 回复次数:13 
请教大家一些关于工作区的问题?
1、我怎么知道那些工作区在使用?在打开那些表?
2、表单中使用数据环境,就是用鼠标拖动字段直接到表单的时候,工作区是怎样分配的?如果我有几个表的话,当表单运行的时候,工作区是怎样分配的?

其实就是想彻底把工作区这个东西搞清楚,总感觉一个工作区只能打开一个表有点别扭,或者我理解不对?
请大家指导。
搜索更多相关主题的帖子: 工作区 
2016-01-06 20:26
tlliqi
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:204
帖 子:15453
专家分:65956
注 册:2006-4-27
得分:3 
vfp中共有32767 个工作区。
当打开一个表是默认在1号工作区
当再打开另一个表是还是在1号工作区
可以通过select n 来指定当前工作区号
select 0 表示尚未使用的最小的工作区号
select 5 设置5号工作区为当前工作区
2016-01-06 20:42
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:2 
可以用别名表示
“数据环境”的Alias属性

2016-01-06 21:13
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:1 
想彻底搞清楚这个问题,不是三言两语就可以的。

授人以渔,不授人以鱼。
2016-01-06 21:24
wcx_cc
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:52
帖 子:352
专家分:1152
注 册:2015-10-2
得分:3 
我是这样用的。如果同时打开3张表,比如用:use 表1 in 1,再 use 表1 in 2,再 use 表1 in 3
当使用其中第2张表时,可以用:sele 2 (或 sele 表2)
再继续使用第1张表时,可以用:sele 1 (或 sele 表1) ....,
只要不关闭表,使用时没有顺序,也没有使用次数,任意连续选用就是了。不用太关心工作区是如何起作用的 ..



2016-01-06 22:57
hu9jj
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:红土地
等 级:贵宾
威 望:396
帖 子:11713
专家分:43267
注 册:2006-5-13
得分:2 
两点经验:
1、打开表时不要指定工作区,用use 表名 in 0的命令让VFP自动选择空闲的工作区,之后用selec 表别名的命令来选择这个表所在的工作区。
2、查找某个表是否被打开,用used("表名")函数。

活到老,学到老! http://www. E-mail:hu-jj@
2016-01-07 07:40
taifu945
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:80
帖 子:1545
专家分:3298
注 册:2012-7-6
得分:1 
一个工作区只能打开一个表是对的呀。你想,如果一个工作区允许多张表,那么你SELECT一个工作区后,对应什么表呢?不还得要再次指定一次表么?
2016-01-07 07:45
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:2 
所谓工作区,其实就是在数据表字段变量前添加的前缀标识符,明白这点,就明白很多为什么。

授人以渔,不授人以鱼。
2016-01-07 08:13
liuxingang28
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:山东济南
等 级:贵宾
威 望:47
帖 子:649
专家分:2156
注 册:2014-2-7
得分:3 
必须搞清楚以下概念:
1. 一个工作区只能打开一个表
2. 一个表可以在多个工作区打开(可以使用 USE 命令的 AGAIN 选项)
3. 工作区隶属于“工作期”。当表单设置为私有数据工作期时,表单的每个实例都有自己的工作期,而每个工作期都有32767个工作区。
4. 使用 set("DataSession")可以知道当前的工作期编号,使用 select()函数可知道当前的工作区编号
5. 使用 use <表> in 0 可以在一个最小的空闲工作区打开表,但并不切换工作区
6. 使用 select 0 命令可以切换到一个最小的空闲工作区,使用 select()可返回当前工作区的编号,select(0)返回最小的空闲工作区编号,select(1)返回最大的空闲工作区编号
7. 通过判断 alias()的返回值是否为空,可以知道一个工作区是否有表打开
8. 通过判断 used()的返回值,可以知道一个表是否被打开,通过判断 select("表别名")的返回值可以知道一个表在哪个编号的工作区打开
……

泉城飞狐
2016-01-07 08:51
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:190
帖 子:3125
专家分:8340
注 册:2015-3-25
得分:3 
以下是引用hu9jj在2016-1-7 07:40:43的发言:

两点经验:
1、打开表时不要指定工作区,用use 表名 in 0的命令让VFP自动选择空闲的工作区,之后用selec 表别名的命令来选择这个表所在的工作区。
2、查找某个表是否被打开,用used("表名")函数。

正点,不能自己指定工作区,如果自己指定的话,当你打开了很多表后,你就不知道那个区是打开了那个表了。
use 表1 in 0 &&在最小的工作区打开表1,如果表1是第1个打开的,有可能是在工作区1,
brow
use 表2 in 0 &&假如是在工作区2打开表2
brow
use in 表1   &&把表1关闭了
use 表3 in 0 &&在最小的工作区打开表3,因为表1给你关闭了,此时,表3应该在工作区1,二不是工作区3
if used("表2") &&如果表2给打开了,
   select 表2  &&选择表2的工作区为当前工作区
   ?select()   &&显示当前工作区的区号
   brow
else
   use 表2 in 0
endif


我以前就是自己指定工作区的,后来表多了,出乱子了,重新改了很多地方
以前是
use 表1 in 1
use 表2 in 2
使用的时候
select 1
brow
select 2
brow
但当你打开了N个表后,就
select n
就不知道这个表是什么表了。。。

[此贴子已经被作者于2016-1-7 09:24编辑过]

2016-01-07 08:58



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-460886-1-1.html




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

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