我正在使用IISBeta2来创建一个VS2010托管的。我添加了一个SQL Server数据库文件作为简单的数据存储,然后生成了一些Linq to SQL类来与它交互。
当Linq to SQL尝试连接到数据库时,我遇到的问题就出现了。我得到以下错误:
数据库'master‘中的CREATE DATABASE权限被拒绝。尝试为文件c:\Source\SampleApp\App_Data\GameData.mdf附加自动命名的数据库失败。存在同名的数据库,或者无法打开指定的文件,或者该文件位于UNC共享上。
为了解决前面的问题,我已经将web.config更改为不使用user实例:
<add name="GameDataConnectionString" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\GameData.mdf;Integrated Security=True;User Instance=False"
providerName="System.Data.SqlClient" />我的第一反应是应用程序池的用户帐户(网络服务)无法打开该文件,因此我授予了对数据库文件和日志文件的完全控制权限,但这没有帮助。
有趣的是,如果我将应用程序池更改为在本地系统下运行,则一切工作正常。是否还有其他内容需要我授予网络服务访问权限?
发布于 2010-01-25 03:35:29
Yopu必须使用Sql Management Studio Express并添加网络服务帐户作为登录名。然后为其分配对指定数据库的DBO权限,或者简单地为其分配sysadmin角色。注安装SQL Server2005任何版本时,您都可以使用初始选项来设置服务的登录帐户。如果您指定网络服务。默认情况下,网络服务帐户将被授予sysadmin角色。
希望这能有所帮助
发布于 2010-01-25 03:38:46
如果您没有使用<identity impersonate="true"/>,那么您的应用程序池用户没有足够的权限访问您的数据库。
您还可以创建一个数据库用户(SQL身份验证)并将其凭证(用户名/密码)固定到您的连接字符串中。这就是我通常做的。
https://stackoverflow.com/questions/2128405
复制相似问题