服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Sql Server - 在数据库‘master’中拒绝CREATE DATABASE权限问题的解决方法

在数据库‘master’中拒绝CREATE DATABASE权限问题的解决方法

2019-12-08 21:40MSSQL教程网 Sql Server

今天使用Linq To SQL,要求判断数据库是否存在,不存在是自动创建数据库。

代码如下:


public partial class CMS_DBDataContext 

partial void OnCreated() 

// 如果数据库不存在则创建数据库 
if (!this.DatabaseExists()) 

this.CreateDatabase(); 



遇到了以下错误:在数据库‘master'中拒绝CREATE DATABASE权限。 

经查阅资料得知,运行 SQL Server 数据库,就必须在实例下创建数据库,不管是直接创建、还是附加、还是还原,总之都得在实例下创建。 

于是,修改连接字符串, 

<add name="SE_DBConnectionString" connectionString="Data Source=.\sqlexpress;Initial Catalog=SE_DB;Integrated Security=True;Pooling=False;User Instance=True" providerName="System.Data.SqlClient" /> 

添加User Instance=True,即可使用实例成功创建数据库。 

解决方法二: 

为相应登陆数据库的用户分配数据库管理员角色,也可以解决这个错误。如在ASP.NET中,NETWORK SERVICE用户会访问数据库,可将此用户的数据库角色设置为数据库管理员角色。总之,保证登陆的用户有权创建,修改或删除数据库即可。

延伸 · 阅读

精彩推荐