2

我有一个旧的 Delphi 7 应用程序,我修复了一些。它使用 Access 数据库。大约有 150 个用户都远程打开应用程序并并行访问数据库。在我开始修复之前(呵呵),这很好用(除了 Delphi 应用程序中的错误),即使数据库偶尔有点慢。

现在我添加了一些功能和两个新表,我突然遇到了非常奇怪的问题。

  1. MSAccess 可以访问数据库(2010 版)。这意味着: 双击文件将打开 MSAccess 并打开数据库文件。
  2. Delphi 7 应用程序可以访问数据库。
  3. Delphi 应用程序的两个或多个实例可以共享数据库,前提是我将原始 ConnectionString 模式从“ReadWrite”更改为“Share Deny None”(下面的整个连接字符串)。
  4. 一旦 Delphi 应用程序的一个实例运行,数据库文件就不能再通过双击打开了。(当我这样做时没有任何反应)。但是,我可以打开 MSAccess 并从其中打开数据库文件。那可行。

连接字符串:

Provider=Microsoft.Jet.OLEDB.4.0;
User ID=Admin;Data Source=DBPath;
Mode=Share Deny None;
Extended Properties="";
Persist Security Info=False;
Jet OLEDB:System database="";
Jet OLEDB:Registry Path="";
Jet OLEDB:Database Password=****;
Jet OLEDB:Engine Type=5;
Jet OLEDB:Database Locking Mode=1;
Jet OLEDB:Global Partial Bulk Ops=2;
Jet OLEDB:Global Bulk Transactions=1;
Jet OLEDB:New Database Password="";
Jet OLEDB:Create System Database=False;
Jet OLEDB:Encrypt Database=False;
Jet OLEDB:Don`t Copy Locale on Compact=False;
Jet OLEDB:Compact Without Replica Repair=False;
Jet OLEDB:SFP=False

我仍然需要查看 Renaud Bompuis 就共享安全设置提出的所有建议,但我必须为此找到一个管理员,因此可能需要一段时间。

4

1 回答 1

1

如果您的计算机上有数据库的副本,请确保您可以使用 Access 打开它而不会出现任何错误。如果遇到问题,请先解决此问题。也许压缩并修复数据库。

确保您从中打开数据库的远程文件夹已添加到Access 中的受信任位置列表中(与您从中打开数据库的本地文件夹相同)。

如果您可以在本地打开数据库,但不能在远程共享上打开,请确保共享的安全设置允许您对整个共享进行读写访问,以便数据库引擎可以正确创建.laccdb.ldb锁定文件。有关类似问题,
请参阅拆分数据库上的问题 MS Access - “文件已在使用”错误。

基本上,即使其他用户连接到它,Access 也没有理由不能打开远程数据库。

当您在这里提出问题时,请记住发布尽可能多的详细信息。
例如在这里,您应该发布您正在使用的确切连接字符串详细信息;您还应该提及尝试从 Access 打开数据库时收到的确切错误消息,因为它可以帮助我们识别问题。

于 2012-11-07T07:04:07.027 回答