SQL Compact Edition 3.5 – 不允许访问数据库文件
我使用SQL Server Compact 3.5开发了一个应用程序(100%本地,无法访问服务器),它在我的计算机上运行良好。 但是,当我在另一台计算机上部署它时,它显示以下错误:
Access to the database file is not allowed. [ File name = data\BDApepucCE.sdf ]
我部署在Windows XP计算机上。 每当我尝试在数据库上写入时它都会显示此错误,但是,当我阅读时它会起作用。
我在Windows 7计算机上进行了测试,它的工作率为100%,除非通过家庭组(即本地网络)访问该文件,但在读取/写入时它都失败了。
平台:Windows 7,Visual Studio 2010和.NET 4 Client Profile
确保使用|DataDirectory|
在您的连接字符串中。 这是一个例子
connectionString="Data Source=|DataDirectory|MyDB.sdf"
我和你有完全相同的问题我通过添加| DataDirectory |来设法修复它 到我的连接字符串。
祝好运。
这对我有用: http : //solutionevangelist.com/community/discussion/20/access-to-the-database-file-is-not-allowed.-system.data.sqlserverce.sqlceexception/p1
它通常是一个权限问题。 我通过GUI或使用,为App_Data中的.sdf文件赋予“Everyone”完全权限
icacls database.sdf /grant Everyone:F
我也有同样的问题。 我的解决方案是在我部署它并且sdf文件签入(即只读)时在TFS / SourceControl中,这导致了与上面完全相同的错误。 当我检出sdf文件并再次部署时,一切都很好。 我想我会分享一下,以防其他TFS用户遇到同样的问题。
以下是另外两条建议:
- 尝试以管理员身份运行Visual Studio
- 检查sdf文件上是否设置了’readonly’属性
此外,您可能需要检查并查看您的应用程序池是否正在使用网络服务(而不是应用程序池),并且网络服务权限设置为您的AppData文件夹下的完全控制。 这是我前一段时间的问题而且我忘了我是怎么做到的,但是这个问题让我想起了我是怎么做到的。
您只需要在IIS菜单“Web服务扩展”下允许“服务器端包含”
这解决了我所有的问题。
以下解决方案对我有用:
Windows中的“程序文件”受到保护,因此普通用户无法在此处写入,您的应用程序可能仅适用于管理员用户。
将数据库的数据文件夹路径更改为所有用户都有权写入的位置。
这不是典型的原因,但是当我的连接字符串具有到CE SDF文件的错误路径时,我遇到了此错误消息。 一旦我修复了错误就消失了。
只需以管理员身份运行您的应用 我用这个解决了我的问题。