首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用网络服务帐户附加到sql server express db文件时出现问题。

使用网络服务帐户附加到sql server express db文件时出现问题。
EN

Stack Overflow用户
提问于 2010-01-25 03:26:33
回答 2查看 1K关注 0票数 2

我正在使用IISBeta2来创建一个VS2010托管的。我添加了一个SQL Server数据库文件作为简单的数据存储,然后生成了一些Linq to SQL类来与它交互。

当Linq to SQL尝试连接到数据库时,我遇到的问题就出现了。我得到以下错误:

数据库'master‘中的CREATE DATABASE权限被拒绝。尝试为文件c:\Source\SampleApp\App_Data\GameData.mdf附加自动命名的数据库失败。存在同名的数据库,或者无法打开指定的文件,或者该文件位于UNC共享上。

为了解决前面的问题,我已经将web.config更改为不使用user实例:

代码语言:javascript
运行
复制
<add name="GameDataConnectionString" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\GameData.mdf;Integrated Security=True;User Instance=False"
  providerName="System.Data.SqlClient" />

我的第一反应是应用程序池的用户帐户(网络服务)无法打开该文件,因此我授予了对数据库文件和日志文件的完全控制权限,但这没有帮助。

有趣的是,如果我将应用程序池更改为在本地系统下运行,则一切工作正常。是否还有其他内容需要我授予网络服务访问权限?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-01-25 03:35:29

Yopu必须使用Sql Management Studio Express并添加网络服务帐户作为登录名。然后为其分配对指定数据库的DBO权限,或者简单地为其分配sysadmin角色。注安装SQL Server2005任何版本时,您都可以使用初始选项来设置服务的登录帐户。如果您指定网络服务。默认情况下,网络服务帐户将被授予sysadmin角色。

希望这能有所帮助

票数 2
EN

Stack Overflow用户

发布于 2010-01-25 03:38:46

如果您没有使用<identity impersonate="true"/>,那么您的应用程序池用户没有足够的权限访问您的数据库。

您还可以创建一个数据库用户(SQL身份验证)并将其凭证(用户名/密码)固定到您的连接字符串中。这就是我通常做的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2128405

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档