现在的位置: 首页 >> 数据库 >> FoxPro >> foxpro 取得离线视图
添加时间:2005-8-17 来源:网教中国 作者:
foxpro 取得离线视图

获取离线视图是简单的:确信包含了视图定义的数据库是当前数据库并使用新的 createoffline() 函数。语法如下:

createoffline(<ViewName> [, <Path>])

<ViewName> 是离线视图的名字。任何视图都可以离线;你不用特别定义一个视图作为“离线表”。

选项 <Path> 是要建立的DBF的目录和文件名。如果你未指定<Path>, VFP 将在当前目录中建立一个与视图同名的表(例如, 如果视图名字是LV_CUSTOMER, 表名将是LV_CUSTOMER.DBF)。

注意VFP 文档中关于该参数的描述是错误的; 它规定你只能为该表指定一个目录, 但实际上你也可以指定名字 (尽管扩展名不是必须的)。

如果视图成功的离线,createoffline() 返回.T.。

如果视图已经离线,如果你使用了第二个参数而又未指定文件名, 如果视图表或支持性表缓存文件已经存在 (该行为有望在将来的版本中得到改变;依我看来, 它不会妨害set safety), 或源表不能打开,则返回 .F.。

以下是该函数的一个例子:

llSuccess = createoffline('LV_CUSTOMER', 'OFFLINE\LV_CUSTOMER')

该例试图让LV_CUSTOMER 视图离线并在当前目录下的OFFLINE子目录中建立一个叫LV_CUSTOMER.DBF 的表。

这里是关于生成离线视图的其它要注意的事:

  • createoffline() 打开视图所基于的表而不是视图本身。
  • 如果视图离线,dbgetprop(<ViewName>, 'View', 'Offline') 返回.T.。
  • VFP 5.0 (包括5.0a) 有一个bug:如果 createoffline() 返回.F., 指明视图因某种原因而未能离线, dbgetprop(<ViewName>, 'View', 'Offline') 出乎意料的返回.T.。dropoffline()也不会正常工作; 它返回.F。指明视图不能离线, 而且即使它确实已经不是离线视图, dbgetprop(<ViewName>, 'View', 'Offline') 继续返回.T., 然而; 在视图联线模式或管理模式下打开视图将会得到一条 "对象不是一个离线视图" 错误。幸运的是, 如果你解决该问题而致使createoffline() 失败, 你可以再次使用它来让视图离线.

上一篇:foxpro 用离线视图工作 下一篇:附表:"选项"对话框的说明(3)
大部分文章摘自网上,如有侵犯您的权益请与我们联系,我们会第一时间进行处理,谢谢! [ 打印文章 ] [ 关闭窗口 ]
推荐文章
·使用FOXPRO编一个完整的软件
·Foxpro 程序的调试
·Foxpro 程序的测试与调试
·Foxpro 默认的工作环境
·Foxpro 创建你自己的向导
·附表:"选项"对话框的说明(2)
·附表:"选项"对话框的说明(3)
·foxpro 更新源表
·foxpro 多个本地数据
·使用视图 - 尝试一
相关文章
·foxpro 用离线视图工作
·foxpro 更新源表
·foxpro 让视图与数据源相连
·foxpro 刷新(Refreshing) 离线视
·foxpro 机动查询和数据输入
·foxpro 多个本地数据
·foxpro 维护源表
·foxpro 结论
·使用 Visual FoxPro 的 ActiveX
·使用 Visual FoxPro 的 ImageLis
最新文章
·什么是项目管理器,数据库和表的
·见识一下面向对象的编程
·FOXPRO 对象、属性、事件、方法
·FOXPRO 常用的对象、属性、事件(
·FOXPRO常用编程命令及常用函数
·使用FOXPRO编一个完整的软件
·Foxpro 编程中的一些小技巧
·Foxpro 程序的调试
·Foxpro 软件的编译及制作安装盘
·Foxpro 更多对象
Google