如何解决FoxPro临时文件问题
| 我们具有以下Visual FoxPro 9代码行INDEX ON batchno TO temp FOR !DELETED()
我们遇到了一个问题,即FoxPro编译的应用程序将在其中运行,尝试枚举文件夹的内容,查找临时文件,创建临时文件(名为temp.idx的数据库),然后继续进行进一步处理以引用该文件。临时数据。
当我们使用带有NFS文件系统的Novell目录服务器时,这似乎工作正常。但是,现在我们已经转移到具有NTFS文件系统的MS Active Directory服务器,我们遇到了一个问题,即已编译的FoxPro应用程序不再能够写入该文件。
发生错误时,Process Monitor显示以下输出:
Operation: CreateFile
Result: SHARING VIOLATION
Desired Access: Generic Read/Write
disposition: OverwriteIf
Options: Synchronous IO Non-Alert,Non-Directory File
Attributes: N
ShareMode: None
AllocationSize: 0
我很好奇是否有另一种方法可以解决这种情况,在这种情况下,我们不必担心应用程序在尝试写入文件时保持文件处于使用状态(大概已读取),但由于已被使用,因此随后失败。
解决方法
.IDX文件是包含一个索引的独立索引文件,而.CDX是可以包含多个索引的复合索引文件。
这是权限问题-当您以网络管理员身份运行它时可以工作吗?
EXE编译在哪个版本的FoxPro / Visual FoxPro中?
客户端和服务器操作系统是什么?
, 使用哪个操作系统很重要!如果该程序在Windows Vista,7或Server 2008上运行,则无法无限制地在任何位置创建文件。
最好的方法是在用户的TEMP目录中创建此临时索引。在这里,您始终拥有写或删除文件的完整权限。
如果你只是用
INDEX ON batchno TO temp FOR !DELETED()
IDX将在默认目录中创建。如果此目录为C:\\ Program Files ...,则Windows的UAC不允许将其写入该目录,并将文件重定向到c:\\ Windows下某个位置的临时目录。
使用SYS(2023),您可以获取用户的TEMP目录。
所以试试这个:
INDEX ON batchno TO (SYS(2023) + \"\\temp.idx\") FOR !DELETED()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。