我正在尝试使用 System.Data.OleDb.OleDbConnection 连接到 Access 数据库文件。我需要以只读模式连接,因为另一个应用程序同时使用它。我可以以读/写方式连接到数据库,没有问题,但似乎无法在任何地方找到正确的只读字符串。
我已经尝试过:
Provider=Microsoft.ACE.OLEDB.12.0;数据源={0};持久安全信息=False;Mode=读取
Provider=Microsoft.ACE.OLEDB.12.0;数据源={0};持久安全信息=False;扩展属性=“ReadOnly=true;”
谢谢。
编辑:
(我应该在原来的问题中添加更多信息。)
当 Access 数据库位于本地计算机上时,我可以成功连接到该数据库,但是当我尝试使用连接字符串连接到远程计算机上的 Access 数据库时
Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Persist Security Info=False;Mode=Read
我会收到以下错误:
System.Data.OleDb.OleDbException (0x80004005): The Microsoft Office Access database engine cannot open or write to the file '{0}'. It is already opened exclusively by another user, or you need permission to view and write its data.
我的应用程序正在本地系统帐户下的 Windows 服务中运行。
最佳答案
我认为这必须通过数据库管理员控制的用户权限来处理,或者使用您可以控制的记录集的不同游标类型来处理。我不认为连接字符串指定 Access 模式,它只是让您到达那里。 ;)
关于ms-access - Access 数据库的只读连接字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5942936/